You do not have permission to edit this page, for the following reason:

You are not allowed to execute the action you have requested.


You can view and copy the source of this page.

x
 
1
==Abstract==
2
3
Being capable of predicting seakeeping capabilities in the time domain is of great interest for the marine and offshore industry. However, most computer programs used in the industry work in the frequency domain, with the subsequent limitation in the accuracy of their model predictions. The main objective of this work is the development of a time domain solver based on the finite element method capable of solving multi-body seakeeping problems on unstructured meshes. In order to achieve such an objective, several techniques are combined: the use of an efficient algorithm for the free surface boundary conditions, the use of deflated conjugate gradients, and the use of a graphic processing unit for speeding up the linear solver. The results obtained results by the developed model showed good agreement with analytical solutions, experimental data for an actual offshore structure model, as well as numerical solutions obtained by other numerical method. Also, a simulation with sixteen floating bodies was carried out in a affordable CPU time, showing the potential of this approach for multi-body simulation.
4
5
==1. Introduction==
6
7
Seakeeping is a topic of great interest in naval and offshore engineering. This interest is growing in the last years due to the boost given by the development of marine renewable energies. In this context, the development of time-domain seakeeping programs is a main request from the industry. Moreover, the simulation of multi-body systems is a key point in the development of more efficient marine renewable technologies such as wave energy converters, floating wind turbines, etc.
8
9
Up to date the numerical simulation of seakeeping has been mostly carried out using the frequency domain solvers. The reason might be that the computational cost of time domain simulations were too high and computational time was too long. Moreover, assumptions like linear waves and the harmonic nature of water waves made the frequency domain to be the right choice. However, nowadays computing capabilities make possible to carry out numerical simulations in the time domain in a reasonable time, with the advantage of making easier bringing into the algorithm non-linearities when coupling with other phenomena. Furthermore, in the frequency domain, the simulation of multi-body systems requires calculating the interaction among the bodies, which increases quickly the computational effort as the number of bodies increase. On the other hand, if simulating in the time, domain, the interaction among bodies is solved in a natural way without leading to a big increase of computational effort.
10
11
Regarding the numerical method usually adopted, the boundary element method (BEM) has dominated over others like finite element method (FEM). The main advantage of BEM over FEM resides in the fact that only boundary meshes are required, while FEM demands meshing the whole three dimensional volume, with the corresponding increase in the number of variables of the discrete problem. However, despite of the higher number of variables required by FEM, it is not clear that BEM has to be more efficient. Mostly due to the sparse pattern in FEM and the large availability of iterative solvers as well as preconditioner that can improve the resolution of the corresponding linear system of equations. In [<span id='cite-1'></span>[[#1|1]]] Cai et al. a heuristic comparison between both methods is given and demonstrate that a solution to the boundary value problem can be obtained more efficiently by the FEM for large problems.
12
13
In the last decade, there have been extensive applications of the finite element method (FEM) to free surface problems. For example, Oñate and García [<span id='cite-2'></span>[[#2|2]]] presented a stabilized FEM for fluid structure interaction in the presence of free surface where the latter was modelled by solving a fictitious elastic problem on the moving mesh. In [<span id='cite-3'></span>[[#3|3]],<span id='cite-4'></span>[[#4|4]]] Löhner et al. developed a FEM capable of tracking violent free surface flows interacting with objects. Also García et al. [<span id='cite-5'></span>[[#5|5]]] developed a new technique to track complex free surface shapes. However, many works like the previous ones are based on solving the Navier-Stokes equations, too expensive computationally speaking when it comes to simulating real problems regarding ocean waves interacting with floating structures. These sorts of problems can be more cheaply simulated using potential flow theory along with Stokes perturbation approximation
14
15
<span id='bbib22'></span><span id='bbib7'></span><span id='_Ref278008821'></span><span id='bbib2'></span><span id='bbib29'></span><span id='bbib16'></span><span id='_Ref278008823'></span><span id='_Ref278008825'></span>With regards to wave–body interaction problems, there has been extensive work as well in the last decade. In [<span id='cite-6'></span>[[#6|6]]], Wu et al. used both the FEM and the mixed FEM to analyze the two-dimensional (2-D) nonlinear transient water wave problems. Later Wu and Taylor [<span id='cite-7'></span>[[#7|7]]] made a detailed comparison between FEM and the boundary element method (BEM) for the nonlinear free surface flow problem and found that the former was more efficient in terms of both CPU and memory requirement. Greaves et al. [<span id='cite-8'></span>[[#8|8]]] employed quad-tree-based unstructured meshes to model fully nonlinear waves in 2D, using an ALE formulation in structured meshes. In [<span id='cite-9'></span>[[#9|9]]] an hp-element technique was adopted to simulate the 2-D free surface flow problem. Application of FEM schemes to simulated interactions between waves and 3-D fixed structures in numerical tanks used moving meshes along with an explicit time marching scheme for the free surface boundary condition were presented in [<span id='cite-10'></span>[[#10|10]]] and [<span id='cite-11'></span>[[#11|11]]]. However, in those cases, remeshing and interpolation were needed, which leads to a high CPU cost. Westhuis [<span id='cite-12'></span>[[#12|12]]] in his PhD dissertation developed a FEM code for nonlinear waves and focussed in the development of groups of waves. The code relied in some specific structured mesh configurations and no body interaction was studied. Hu et al. [<span id='cite-13'></span>[[#13|13]]] applied FEM to study the case of a vertical under forced motions based on the works [5] and [6]. Turnbull et al. [<span id='cite-14'></span>[[#14|14]]] coupled structured and unstructured meshes to simulate 2-D wave–body interactions. The vertical velocity at nodes belonging to the free surface required a prescribed number of nodes to be aligned vertically. Wu et al. [<span id='cite-15'></span>[[#15|15]]] solved a 3D problem using a semistructured mesh in the vertical direction. This way the nodes will be aligned vertically and the vertical derivative at the free surface can be easily estimated by finite difference. Wang et al. [<span id='cite-16'></span>[[#16|16]]] used FEM to study the effect of second order wave sloshing within a tank in 2D. The 4<sup>th</sup> order Runge Kutta method was used as a time marching scheme for the free surface boundary condition. A FEM solver for a second order wave diffraction by an array of vertical cylinder using semistructured mesh has been presented in [<span id='cite-17'></span>[[#17|17]]]. Again, in order to estimates vertical velocity at the free surface nodes it is required a prescribed number of nodes to be aligned vertically. An explicit fourth-order Adams–Bashforth scheme was used for the free surface boundary condition to march in time. Later on the same authors in [<span id='cite-18'></span>[[#18|18]]] used a structured mesh based on rectangular elements to study second-order resonance effects. Yan et al. [<span id='cite-19'></span>[[#19|19]]] applied the fully non-linear potential for modelling overturning waves. To achieve that, a moving mesh technique was adopted to track down the free surface. Consequently, computational times are large. Recently, Song et al. developed a new scaled boundary finite element method (SBFEM) for linear waves and structure interaction [<span id='cite-20'></span>[[#20|20]]]. The SBFEM works in the frequency domain, and base functions for boundary elements based on Hankel functions were used for unbounded sub-domains were waves are to disappear, decreasing the number of elements needed for the simulation which improves the numerical efficiency of the method.
16
17
Despite of the great effort invested in the last years to the development of FEM algorithms, to the authors’ knowledge, yet there has not been developed a fast FEM (by fast we mean in the order of minutes for practical problems) for solving first order wave structure interaction in the time domain using unstructured meshes. The use of structure or semi-structures meshes is a big limitation since it limits the complexity of the geometry to be used. In this study we present a FEM for wave-structure interaction that can be used with unstructured meshes. Besides, since it is based on Stokes wave theory, no re-meshing or moving mesh technique are needed, which keeps computational costs and computational times low. The algorithm has been adapted to include non-linear external forces, like those used to define mooring systems.
18
19
<span id='_GoBack'></span>The outline of this paper is as follows. In section two, the statement of the governing equations of the first order diffraction-radiation problem of a set of floating bodies is presented. In section three the FEM formulation is presented, the free surface and radiation boundary condition are applied to the problem, and the boundary condition on the bodies and the body dynamics solution are explained in detailed. The accuracy of the new formulation for analysis of waves and floating structures interaction is verified in different validation cases in section four, comparing against analytical, experimental and BEM solutions. Finally, section 5 contains the conclusions of this work.
20
21
==2. Problem statement==
22
23
==2.1 Governing equations==
24
25
We consider the first order diffraction-radiation problem of a set of floating bodies.
26
27
{| class="formulaSCP" style="width: 100%; text-align: center;" 
28
|-
29
| 
30
{| style="text-align: center; margin:auto;" 
31
|-
32
| <span id='ZEqnNum139116'></span> <math>{\nabla }^2\varphi =0</math> in  <math>\Omega </math>
33
|}
34
| style="width: 5px;text-align: right;white-space: nowrap;" | (1)
35
|}
36
37
{| class="formulaSCP" style="width: 100%; text-align: center;" 
38
|-
39
| 
40
{| style="text-align: center; margin:auto;" 
41
|-
42
| <span id='ZEqnNum264352'></span> <math>{\partial }_t\varphi +g\eta =-P_a/\rho +C</math> on  <math>z=0</math> (dynamic free surface boundary condition)
43
|}
44
| style="width: 5px;text-align: right;white-space: nowrap;" | (2)
45
|}
46
47
{| class="formulaSCP" style="width: 100%; text-align: center;" 
48
|-
49
| 
50
{| style="text-align: center; margin:auto;" 
51
|-
52
| <span id='ZEqnNum899014'></span> <math>{\partial }_t\eta -{\partial }_z\varphi =0</math> on  <math>z=0</math> (kinematic free surface boundary condition)
53
|}
54
| style="width: 5px;text-align: right;white-space: nowrap;" | (3)
55
|}
56
57
{| class="formulaSCP" style="width: 100%; text-align: center;" 
58
|-
59
| 
60
{| style="text-align: center; margin:auto;" 
61
|-
62
| <span id='ZEqnNum131060'></span> <math>{\partial }_z\varphi =0</math> on  <math>z=-H</math>
63
|}
64
| style="width: 5px;text-align: right;white-space: nowrap;" | (4)
65
|}
66
67
{| class="formulaSCP" style="width: 100%; text-align: center;" 
68
|-
69
| 
70
{| style="text-align: center; margin:auto;" 
71
|-
72
| <span id='ZEqnNum313886'></span> <math>\nabla \varphi \cdot \boldsymbol{n}_B=\boldsymbol{v}_B\cdot \boldsymbol{n}_B</math> on  <math>{\Gamma }_B</math>
73
|}
74
| style="width: 5px;text-align: right;white-space: nowrap;" | (5)
75
|}
76
77
where  <math>\varphi </math> and  <math>\eta </math> are the first order potential and free surface elevation respectively;  <math>\Omega </math> is the fluid domain bounded by  <math>z=0</math> ;  <math>P_a</math> is the atmospheric pressure;  <math>\rho </math> is the water density; C is a constant value;  <math>{\Gamma }_B</math> represents the wetted surface of the present bodies;  <math>\boldsymbol{v}_B</math> represent the local body velocity on the body surface; and  <math>H</math> is the water depth. The domain is assumed to be infinite in the horizontal directions.
78
79
==2.2 Velocity potential decomposition==
80
81
The aim of this work is to simulate the dynamics of a set of floating bodies subjected to the action of waves. To do so, we will first model the environment as the sum of a number of airy waves. This can be expressed in terms of a velocity potential given by:
82
83
{| class="formulaSCP" style="width: 100%; text-align: center;" 
84
|-
85
| 
86
{| style="text-align: center; margin:auto;" 
87
|-
88
| <math>\psi =\sum_m\frac{A_mg}{{\omega }_m}\frac{cosh\left(\vert \boldsymbol{k}_m\vert (H+z)\right)}{cosh\left(\vert \boldsymbol{k}_m\vert H\right)}cos\left(\vert \boldsymbol{k}_m\vert (xcos{\alpha }_m+\right. </math><math>\left. ysin{\alpha }_m-{\omega }_mt+{\delta }_m\right)</math>
89
|}
90
| style="width: 5px;text-align: right;white-space: nowrap;" | (6)
91
|}
92
93
where  <math>A_m</math> are the wave amplitudes;  <math>{\omega }_m</math> are the wave frequencies;  <math>\boldsymbol{k}_m</math> are the wave numbers;  <math>{\alpha }_m</math> are the wave directions; and  <math>{\delta }_m</math> are wave phases.  From this point on, we will refer to  <math>\psi </math> as the incident potential. This potential, along with the dispersion relation <math>{\omega }_m^2=g\vert \boldsymbol{k}_m\vert tanh\left(\vert \boldsymbol{k}_m\vert H\right)</math> , fulfils Eqs. <span id='cite-ZEqnNum139116'></span>[[#ZEqnNum139116|(1)]]-<span id='cite-ZEqnNum131060'></span>[[#ZEqnNum131060|(4)]], and therefore is solution of the mathematical model in the absence of bodies.
94
95
In order to obtain the solution to the governing equations, we will use a velocity potential decomposition. Let  <math>\varphi </math> be the solution to the governing equations. Then   <math>\varphi </math> can be decomposed as  <math>\varphi =\psi +\phi </math> , where  <math>\phi </math> represents the velocity potential of waves diffracted and radiated by the bodies.
96
97
Introducing the velocity potential decomposition into the governing equations we obtained the equation to be fulfilled by  <math>\phi </math> :
98
99
{| class="formulaSCP" style="width: 100%; text-align: center;" 
100
|-
101
| 
102
{| style="text-align: center; margin:auto;" 
103
|-
104
| <span id='ZEqnNum863995'></span> <math>{\nabla }^2\phi =0</math> in  <math>\Omega </math>
105
|}
106
| style="width: 5px;text-align: right;white-space: nowrap;" | (7)
107
|}
108
109
{| class="formulaSCP" style="width: 100%; text-align: center;" 
110
|-
111
| 
112
{| style="text-align: center; margin:auto;" 
113
|-
114
| <math>{\partial }_t\phi +g\eta =-P_a/\rho +C{}'</math> on  <math>z=0</math> (dynamic free surface boundary condition)
115
|}
116
| style="width: 5px;text-align: right;white-space: nowrap;" | (8)
117
|}
118
119
{| class="formulaSCP" style="width: 100%; text-align: center;" 
120
|-
121
| 
122
{| style="text-align: center; margin:auto;" 
123
|-
124
| <math>{\partial }_t\eta -{\partial }_z\phi =0</math> on  <math>z=0</math> (kinematic free surface boundary condition)
125
|}
126
| style="width: 5px;text-align: right;white-space: nowrap;" | (9)
127
|}
128
129
{| class="formulaSCP" style="width: 100%; text-align: center;" 
130
|-
131
| 
132
{| style="text-align: center; margin:auto;" 
133
|-
134
| <math>{\partial }_z\phi =0</math> on  <math>z=-H</math>
135
|}
136
| style="width: 5px;text-align: right;white-space: nowrap;" | (10)
137
|}
138
139
{| class="formulaSCP" style="width: 100%; text-align: center;" 
140
|-
141
| 
142
{| style="text-align: center; margin:auto;" 
143
|-
144
| <span id='ZEqnNum486242'></span> <math>\nabla \phi \cdot \boldsymbol{n}_B=\left(\boldsymbol{v}_B-\right. </math><math>\left. \nabla \psi \right)\cdot \boldsymbol{n}_B</math> on  <math>{\Gamma }_B</math>
145
|}
146
| style="width: 5px;text-align: right;white-space: nowrap;" | (11)
147
|}
148
149
Our purpose is to find  <math>\phi </math> for a given incident potential and given <math>\boldsymbol{v}_B</math> . To do so, we will solve Eqs. <span id='cite-ZEqnNum863995'></span>[[#ZEqnNum863995|(7)]]-<span id='cite-ZEqnNum486242'></span>[[#ZEqnNum486242|(11)]] in a finite domain by means of the finite element method.
150
151
==2.3 Radiation condition and wave dissipation==
152
153
Waves represented by  <math>\phi </math> are born at the bodies and propagate in all directions away from the bodies. These waves have to either be dissipated or to be let go out the domain so they will not come back and interact with the bodies. Then, we will make use of a Sommerfeld radiation condition at the edge of the computational domain:
154
155
{| class="formulaSCP" style="width: 100%; text-align: center;" 
156
|-
157
| 
158
{| style="text-align: center; margin:auto;" 
159
|-
160
| <span id='ZEqnNum616279'></span> <math>{\partial }_t\phi +c\nabla \phi \cdot \boldsymbol{n}_R=</math><math>0</math> on  <math>{\Gamma }_R</math>
161
|}
162
| style="width: 5px;text-align: right;white-space: nowrap;" | (12)
163
|}
164
165
where  <math>{\Gamma }_R</math> is the surface limiting of the domain in the horizontal directions, and  <math>c</math> is a prescribed wave velocity. Eq. <span id='cite-ZEqnNum616279'></span>[[#ZEqnNum616279|(12)]] will let waves moving at velocity  <math>c</math> to escape out the domain. However, waves with very different velocities will not be leaving the domain. Then, wave dissipation is inserted into the dynamic free surface boundary condition by varying the pressure such that:
166
167
{| class="formulaSCP" style="width: 100%; text-align: center;" 
168
|-
169
| 
170
{| style="text-align: center; margin:auto;" 
171
|-
172
| <span id='ZEqnNum345197'></span> <math>P_a/\rho =\kappa (\boldsymbol{x)}{\partial }_z\phi </math>
173
|}
174
| style="width: 5px;text-align: right;white-space: nowrap;" | (13)
175
|}
176
177
where  <math>\kappa (\boldsymbol{x)}</math> is a damping coefficient. Eq. <span id='cite-ZEqnNum345197'></span>[[#ZEqnNum345197|(13)]] increases pressure when the free surface is moving upwards, while decreases the pressure when the free surface is moving downwards. By doing this, energy is transfer from the waves to the atmosphere and waves are damped. However, the coefficient  <math>\kappa (\boldsymbol{x)}</math> will be set to zero in the area nearby the bodies so damping will no affect to the wave structure interaction.
178
179
Combining the dynamic and kinematic boundary condition, introducing Eq.<span id='cite-ZEqnNum345197'></span>[[#ZEqnNum345197|(13)]], and adding Eq.<span id='cite-ZEqnNum616279'></span>[[#ZEqnNum616279|(12)]], and choosing  <math>C{}'=0</math> , the governing equations for  <math>\phi </math> becomes:
180
181
{| class="formulaSCP" style="width: 100%; text-align: center;" 
182
|-
183
| 
184
{| style="text-align: center; margin:auto;" 
185
|-
186
| <span id='ZEqnNum328769'></span> <math>{\nabla }^2\phi =0</math> in  <math>\Omega </math>
187
|}
188
| style="width: 5px;text-align: right;white-space: nowrap;" | (14)
189
|}
190
191
{| class="formulaSCP" style="width: 100%; text-align: center;" 
192
|-
193
| 
194
{| style="text-align: center; margin:auto;" 
195
|-
196
| <span id='ZEqnNum152621'></span> <math>{\partial }_{tt}\phi =-g{\partial }_z\phi -\kappa (\boldsymbol{x)}{\partial }_t{\partial }_z\phi </math> on  <math>z=0</math>
197
|}
198
| style="width: 5px;text-align: right;white-space: nowrap;" | (15)
199
|}
200
201
{| class="formulaSCP" style="width: 100%; text-align: center;" 
202
|-
203
| 
204
{| style="text-align: center; margin:auto;" 
205
|-
206
| <span id='ZEqnNum782453'></span> <math>{\partial }_z\phi =0</math> on  <math>z=-H</math>
207
|}
208
| style="width: 5px;text-align: right;white-space: nowrap;" | (16)
209
|}
210
211
{| class="formulaSCP" style="width: 100%; text-align: center;" 
212
|-
213
| 
214
{| style="text-align: center; margin:auto;" 
215
|-
216
| <span id='ZEqnNum823594'></span> <math>\nabla \phi \cdot \boldsymbol{n}_B=\left(\boldsymbol{v}_B-\right. </math><math>\left. \nabla \psi \right)\cdot \boldsymbol{n}_B</math> on  <math>{\Gamma }_B</math>
217
|}
218
| style="width: 5px;text-align: right;white-space: nowrap;" | (17)
219
|}
220
221
{| class="formulaSCP" style="width: 100%; text-align: center;" 
222
|-
223
| 
224
{| style="text-align: center; margin:auto;" 
225
|-
226
| <math>{\partial }_t\phi +c\nabla \phi \cdot \boldsymbol{n}_R=</math><math>0</math> on  <math>{\Gamma }_R</math>
227
|}
228
| style="width: 5px;text-align: right;white-space: nowrap;" | (18)
229
|}
230
231
{| class="formulaSCP" style="width: 100%; text-align: center;" 
232
|-
233
| 
234
{| style="text-align: center; margin:auto;" 
235
|-
236
| <span id='ZEqnNum969284'></span> <math>\eta =-\frac{1}{g}{\partial }_t\phi -\frac{P_a}{\rho g}</math> on  <math>z=0</math> (kinematic free surface boundary condition)
237
|}
238
| style="width: 5px;text-align: right;white-space: nowrap;" | (19)
239
|}
240
241
where the free surface elevation has been decoupled from the problem of obtaining the velocity potential.
242
243
==3. Finite element formulation==
244
245
This section presents the FEM formulation to solve the above equations. This formulation has been developed to be used in conjunction with unstructured meshes. The use of unstructured meshes enhances geometry flexibility and speed ups the initial modelling time. An automatic unstructured grid generator based on the advancing front method is used to generate triangular surface grids and tetrahedral volume meshes.
246
247
Let  <math>Q_h^\ast </math> be the finite element space to interpolate functions, constructed in the usual manner. From this space, we can construct the subspace  <math>Q_{h,\phi }</math> , that incorporates the Dirichlet conditions for the potential  <math display="inline">\phi </math> . The space of test functions, denoted by  <math>Q_h</math> , is constructed as <math>Q_{h,\phi }</math> , but with functions vanishing on the Dirichlet boundary. The weak form of the problem can be written as follows:
248
249
Find   <math>\left[{\phi }_h\right]\in Q_{h,\phi }</math> , by solving the discrete variational problem:
250
251
{| class="formulaSCP" style="width: 100%; text-align: center;" 
252
|-
253
| 
254
{| style="text-align: center; margin:auto;" 
255
|-
256
| <math>\int_{\Omega }\nabla v_h\cdot \nabla {\phi }_hd\Omega =</math><math>\int_{{\Gamma }^B}v_h\cdot {\overset{\frown}{\phi }}_n^Bd\Gamma +</math><math>\int_{{\Gamma }^R}v_h\cdot {\overset{\frown}{\phi }}_n^Rd\Gamma +</math><math>\int_{{\Gamma }^{Z_0}}v_h\cdot {\overset{\frown}{\phi }}_n^{Z_0}d\Gamma +</math><math>\int_{{\Gamma }^{Z_{-H}}}v_h\cdot {\overset{\frown}{\phi }}_n^{Z_{-H}}d\Gamma \mbox{ }\forall v_h\in Q_h</math>
257
|}
258
| style="width: 5px;text-align: right;white-space: nowrap;" | (20)
259
|}
260
261
where <math>{\overset{\frown}{\phi }}_n^B</math> ,  <math>{\overset{\frown}{\phi }}_n^R</math> ,  <math>{\overset{\frown}{\phi }}_n^{Z_0}</math> and  <math>{\overset{\frown}{\phi }}_n^{Z_{-H}}</math> are the potential normal gradients corresponding to the Neumann boundary conditions on bodies, radiation boundary, free surface and bottom, respectively.
262
263
At this point, it is useful to introduce the associated matrix form
264
265
{| class="formulaSCP" style="width: 100%; text-align: center;" 
266
|-
267
| 
268
{| style="text-align: center; margin:auto;" 
269
|-
270
| <span id='ZEqnNum257856'></span> <math>\overline{\overline{\boldsymbol{L}}}\phi =\boldsymbol{b}^B+</math><math>\boldsymbol{b}^R+\boldsymbol{b}^{Z_0}+\boldsymbol{b}^{Z_{-H}}</math>
271
|}
272
| style="width: 5px;text-align: right;white-space: nowrap;" | (21)
273
|}
274
275
where  <math>\overline{\overline{\boldsymbol{L}}}</math> is the standard laplacian matrix, and  <math>\boldsymbol{b}^B</math> ''',''' <math>\boldsymbol{b}^R</math> ''',''' <math>\boldsymbol{b}^{Z_0}</math> and''' ''' <math>\boldsymbol{b}^{Z_{-H}}</math> ''' '''are the vector resulting of integrating the corresponding boundary condition term. Regarding the bottom boundary for the refracted and radiated potential, it is imposed naturally in FEM by  <math>\boldsymbol{b}^{Z_{-H}}=0</math> .
276
277
<span id='MTReference'></span>
278
279
==3.1 Free surface boundary condition==
280
281
Solving the velocity potential free surface boundary condition efficiently is the most important point of the problem stated since this is the where a difference is made when solving the mathematical model in Eqs. <span id='cite-ZEqnNum328769'></span>[[#ZEqnNum328769|(14)]]-<span id='cite-ZEqnNum969284'></span>[[#ZEqnNum969284|(19)]] using FEM.
282
283
The free surface boundary condition represents the temporal evolution of the velocity potential. Therefore, it is commonly used time marching schemes such as the fourth order Runge-Kutta (RK4) and fourth order Adams-Bashforth (AB4). The RK4 is a explicit four steps methods that required estimation of intermediate point to advance from time  <math display="inline">t</math> to time  <math display="inline">t+\Delta t</math> . Then, the Laplace equation has to be solved four times and  <math>{\partial }_z\phi </math> has to be estimated each time. On the other hand, the AB4 is an explicit scheme that only requires solving the Laplace equation and estimate  <math>{\partial }_z\phi </math> once per time step. However the AB4 requires storing information at the free surface of the previous 4 time steps. For both algorithms, RK4 and AB4, the values of  <math>{\partial }_z\phi </math> at the free surface are to be estimated so that the scheme can keep marching in time. Following this reasoning, an implicit scheme looks like an expensive option since convergence of the Laplace solution and the free surface numerical scheme would need to be achieved through an iterating procedure. Moreover, based on a literature review, the estimation of   <math>{\partial }_z\phi </math> is usually carried out by finite difference schemes requiring the first layer of nodes to be vertically aligned. From our point of view this is a big restriction since not completely unstructured meshes can be used near the free surface. In order to overcome the above mentioned limitations, we use a forth order compact Padé scheme [<span id='cite-21'></span>[[#21|21]]]. This scheme is implicit with symmetric stencils, which provides good stability properties and requires solving the linear system in Eq. <span id='cite-ZEqnNum257856'></span>[[#ZEqnNum257856|(21)]] once per time step.
284
285
Although the free surface boundary condition is usually implemented as a Dirichlet boundary condition [<span id='cite-_Ref278008821'></span>[[#_Ref278008821|12]],<span id='cite-_Ref278008823'></span>[[#_Ref278008823|17]],<span id='cite-_Ref278008825'></span>[[#_Ref278008825|18]]] by imposing the value of the velocity potential at the time step to be calculated, in this work is implemented as a Neumann boundary condition that fulfils the flux boundary integral:
286
287
{| class="formulaSCP" style="width: 100%; text-align: center;" 
288
|-
289
| 
290
{| style="text-align: center; margin:auto;" 
291
|-
292
| <math>\boldsymbol{b}^{Z_0}={\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}{\phi }_z^{Z_0}</math>
293
|}
294
| style="width: 5px;text-align: right;white-space: nowrap;" | (22)
295
|}
296
297
Where  <math>{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}</math> ''' is '''the corresponding boundary mass matrix. Rather than obtaining the vector  <math>{\phi }_z^{Z_0}</math> ''' '''and calculating the values of  <math>\boldsymbol{b}^{Z_0}</math> , we will proceed in a different manner. Let’s consider the free surface boundary condition outside the absorbing zone (where the absorbing factor equals zero, which is inside the analysis area).  The forth order compact Padé scheme reads, for Eq.<span id='cite-ZEqnNum152621'></span>[[#ZEqnNum152621|(15)]], as:
298
299
{| class="formulaSCP" style="width: 100%; text-align: center;" 
300
|-
301
| 
302
{| style="text-align: center; margin:auto;" 
303
|-
304
| <span id='ZEqnNum646374'></span> <math>\frac{{\phi }^{n+1}-2{\phi }^n+{\phi }^{n-1}}{\Delta t^2}=</math><math>-g{\partial }_z{\phi }^n-\frac{1}{12}g\left({\partial }_z{\phi }^{n+1}-\right. </math><math>\left. 2{\partial }_z{\phi }^n+{\partial }_z{\phi }^{n-1}\right)</math>
305
|}
306
| style="width: 5px;text-align: right;white-space: nowrap;" | (23)
307
|}
308
309
Introducing Taylor series expansion around time t in Eq. <span id='cite-ZEqn'></span>[[#ZEqn|(23)]], and using Eq. <span id='cite-ZEqnNum152621'></span>[[#ZEqnNum152621|(15)]] , we recover the free surface boundary condition with  <math display="inline">O(\Delta t^4)</math> . Eq. <span id='cite-ZEqnNum646374'></span>[[#ZEqnNum646374|(23)]] is an implicit scheme which has to be solved along with the linear system given in Eq <span id='cite-ZEqnNum257856'></span>[[#ZEqnNum257856|(21)]]. At first sight seems like an iterating procedure should be used requiring solving the linear system several times per time steps. However, this can be avoided by decoupling  <math>{\phi }^{n+1}</math> and. <math>{\partial }_z{\phi }^{n+1}</math> .The decoupling is carried out as follows: from Eq. <span id='cite-ZEqnNum646374'></span>[[#ZEqnNum646374|(23)]] we can write  <math>{\phi }_z^{n+1}</math> as a function of  <math>{\phi }^{n+1}</math> :
310
311
{| class="formulaSCP" style="width: 100%; text-align: center;" 
312
|-
313
| 
314
{| style="text-align: center; margin:auto;" 
315
|-
316
| <span id='ZEqnNum484967'></span> <math>{\partial }_z{\phi }^{n+1}=-10{\partial }_z{\phi }^n-</math><math>{\partial }_z{\phi }^{n-1}-\frac{12}{g\Delta t^2}\left({\phi }^{n+1}-\right. </math><math>\left. 2{\phi }^n+{\phi }^{n-1}\right)</math>
317
|}
318
| style="width: 5px;text-align: right;white-space: nowrap;" | (24)
319
|}
320
321
This approximation is used to evaluate  <math>{\overset{\frown}{\phi }}_z^{Z_0}</math> in  <math>t^{n+1}</math> , and therefore, the integral of   <math>\boldsymbol{b}^{Z_0}</math> ''' '''in  <math>t^{n+1}</math> can be calculated as follows:
322
323
{| class="formulaSCP" style="width: 100%; text-align: center;" 
324
|-
325
| 
326
{| style="text-align: center; margin:auto;" 
327
|-
328
| <span id='ZEqnNum989224'></span> <math>{\left(\boldsymbol{b}^{Z_0}\right)}^{n+1}={\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}{\left({\phi }_z^{Z_0}\right)}^{n+1}=</math><math>{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}\left[-\right. </math><math>\left. 10{\left({\phi }_z^{Z_0}\right)}^n-{\left({\phi }_z^{Z_0}\right)}^{n-1}-\right. </math><math>\left. \frac{12}{g\Delta t^2}\left({\phi }^{n+1}-2{\phi }^n+\right. \right. </math><math>\left. \left. {\phi }^{n-1}\right)\right]</math>
329
|}
330
| style="width: 5px;text-align: right;white-space: nowrap;" | (25)
331
|}
332
333
Introducing Eq. <span id='cite-ZEqnNum989224'></span>[[#ZEqnNum989224|(25)]] into Eq. <span id='cite-ZEqnNum257856'></span>[[#ZEqnNum257856|(21)]] we obtain:
334
335
{| class="formulaSCP" style="width: 100%; text-align: center;" 
336
|-
337
| 
338
{| style="text-align: center; margin:auto;" 
339
|-
340
| <span id='ZEqnNum786075'></span> <math>\left(\overline{\overline{\boldsymbol{L}}}+\frac{12}{g\Delta t^2}{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}\right){\phi }^{n+1}=</math><math>{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}\left(\frac{12}{g\Delta t^2}\left(2{\phi }^n-\right. \right. </math><math>\left. \left. {\phi }^{n-1}\right)-10{\left({\phi }_z^{Z_0}\right)}^n-\right. </math><math>\left. {\left({\phi }_z^{Z_0}\right)}^{n-1}\right)+</math><math>{\left(\boldsymbol{b}^B\right)}^{n+1}+{\left(\boldsymbol{b}^R\right)}^{n+1}</math>
341
|}
342
| style="width: 5px;text-align: right;white-space: nowrap;" | (26)
343
|}
344
345
Eq. <span id='cite-ZEqnNum786075'></span>[[#ZEqnNum786075|(26)]] imposes a strong coupling between the free surface boundary condition and the Laplace equation. This is carried out by modifying the system matrix  <math>\overline{\overline{\boldsymbol{L}}}</math> . Once the system is solved,  <math>{\partial }_z{\phi }^{n+1}</math> at the free surface is obtained using Eq. <span id='cite-ZEqnNum484967'></span>[[#ZEqnNum484967|(24)]].
346
347
Then, whenever the velocity potential is solved at the present time step, the free surface elevation is computed by means of  <math>\eta =-(1/g){\partial }_t\varphi </math> using the following fourth order finite difference scheme:
348
349
{| class="formulaSCP" style="width: 100%; text-align: center;" 
350
|-
351
| 
352
{| style="text-align: center; margin:auto;" 
353
|-
354
| <math>{\eta }^{n+1}=-\frac{1}{g\Delta t}\left(\frac{25}{12}{\varphi }^{n+1}-\right. </math><math>\left. 4{\varphi }^n+3{\varphi }^{n-1}-\frac{4}{3}{\varphi }^{n-2}+\right. </math><math>\left. \frac{1}{4}{\varphi }^{n-3}\right)</math>
355
|}
356
| style="width: 5px;text-align: right;white-space: nowrap;" | (27)
357
|}
358
359
==3.2 Implementing the free surface boundary condition with absorption==
360
361
In order to include the wave damping effect, we discretize Eq. <span id='cite-ZEqnNum152621'></span>[[#ZEqnNum152621|(15)]] as follows:
362
363
{| class="formulaSCP" style="width: 100%; text-align: center;" 
364
|-
365
| 
366
{| style="text-align: center; margin:auto;" 
367
|-
368
| <span id='ZEqnNum683406'></span> <math>\frac{{\phi }^{n+1}-2{\phi }^n+{\phi }^{n-1}}{\Delta t^2}=</math><math>-g{\partial }_z{\phi }^n-\frac{1}{12}g\left({\partial }_z{\phi }^{n+1}-\right. </math><math>\left. 2{\partial }_z{\phi }^n+{\partial }_z{\phi }^{n-1}\right)-</math><math>\kappa (\boldsymbol{x)}\frac{{\partial }_z{\phi }^{n+1}-{\partial }_z{\phi }^{n-1}}{2\Delta t}</math>
369
|}
370
| style="width: 5px;text-align: right;white-space: nowrap;" | (28)
371
|}
372
373
Eq. <span id='cite-ZEqnNum683406'></span>[[#ZEqnNum683406|(28)]] is simply Eq. <span id='cite-ZEqnNum484967'></span>[[#ZEqnNum484967|(24)]] plus a second order finite difference in time for the absorbing term. Then  <math>{\partial }_z{\phi }^{n+1}</math> can be obtained as:
374
375
{| class="formulaSCP" style="width: 100%; text-align: center;" 
376
|-
377
| 
378
{| style="text-align: center; margin:auto;" 
379
|-
380
| <span id='ZEqnNum236241'></span> <math>{\partial }_z{\phi }^{n+1}=-\frac{10g\Delta t}{g\Delta t+6\kappa (\boldsymbol{x)}}{\partial }_z{\phi }^n-</math><math>\left(\frac{g\Delta t-6\kappa (\boldsymbol{x)}}{g\Delta t+6\kappa (\boldsymbol{x)}}\right){\partial }_z{\phi }^{n-1}-</math><math>\frac{12}{g\Delta t^2+6\kappa (\boldsymbol{x)}\Delta t}\left({\phi }^{n+1}-\right. </math><math>\left. 2{\phi }^n+{\phi }^{n-1}\right)</math>
381
|}
382
| style="width: 5px;text-align: right;white-space: nowrap;" | (29)
383
|}
384
385
Proceeding like in the previous section, we obtain:
386
387
{| class="formulaSCP" style="width: 100%; text-align: center;" 
388
|-
389
| 
390
{| style="text-align: center; margin:auto;" 
391
|-
392
| <span id='ZEqnNum421098'></span> <math>\left(\overline{\overline{\boldsymbol{L}}}+\frac{12}{g\Delta t^2+6\kappa (\boldsymbol{x)}\Delta t}{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}\right){\phi }^{n+1}=</math><math>{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}\left(\frac{12}{g\Delta t^2+6\kappa (\boldsymbol{x)}\Delta t}\left(2{\phi }^n-\right. \right. </math><math>\left. \left. {\phi }^{n-1}\right)\right)-{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}\left(\frac{10g\Delta t}{g\Delta t+6\kappa (\boldsymbol{x)}}{\left({\phi }_z^{Z_0}\right)}^n+\right. </math><math>\left. \left(\frac{g\Delta t-6\kappa (\boldsymbol{x)}}{g\Delta t+6\kappa (\boldsymbol{x)}}\right){\left({\phi }_z^{Z_0}\right)}^{n-1}\right)+</math><math>{\left(\boldsymbol{b}^B\right)}^{n+1}+{\left(\boldsymbol{b}^R\right)}^{n+1}</math>
393
|}
394
| style="width: 5px;text-align: right;white-space: nowrap;" | (30)
395
|}
396
397
his implementation has several advantages over traditional implementations such as RK4 and AB4. The linear system has to be solved only once per time step (RK4 requires four times); the free surface numerical scheme is implicit (AB4 and RK4 are explicit); only information from two previous times at the free surface is required (AB4 requires information from four previous times); there is no restriction about the grid structure, hence unstructured meshes can be used with no restriction; and the vertical fluid velocity at the free surface is easily computed using Eq.<span id='cite-ZEqnNum236241'></span>[[#ZEqnNum236241|(29)]].
398
399
Regarding the wave absorption algorithm used in this work, we recognize that more sophisticated absorption mechanism can be found in the literature. However, despite of its simplicity, our experience tell us that the performance of this mechanism is good enough for the purpose of this work. The increase of the number of elements needed for absorbing the waves is not that big compared with the number of elements required for the analysis area, where no wave absorption exists. The element size is usually much smaller in the analysis area, and increases gradually in the absorption area as it gets farther form the analysis area where smaller waves have been already absorbed.
400
401
==3.3 Radiation boundary condition==
402
403
When the fluid domain is unbounded, an implementation of a radiation boundary condition is recommended to avoid artificial wave reflexions at the edges of the computational domain, where waves are supposed to go through without reflection. We make use of the Sommerfeld radiation condition given in Eq. <span id='cite-ZEqnNum616279'></span>[[#ZEqnNum616279|(12)]]. We assume that the waves scattered by the bodies hit the outlet boundary in perpendicular. Then we approximate the radiation condition by:
404
405
{| class="formulaSCP" style="width: 100%; text-align: center;" 
406
|-
407
| 
408
{| style="text-align: center; margin:auto;" 
409
|-
410
| <span id='ZEqnNum864339'></span> <math>{\left({\overset{\frown}{\phi }}_n^R\right)}^{n+1}=</math><math>-\frac{{\phi }^{n+1}-{\phi }^n}{c\Delta t}</math>
411
|}
412
| style="width: 5px;text-align: right;white-space: nowrap;" | (31)
413
|}
414
415
Then the term  <math>\boldsymbol{b}_{{}^{}}^R</math> can be calculated through:
416
417
{| class="formulaSCP" style="width: 100%; text-align: center;" 
418
|-
419
| 
420
{| style="text-align: center; margin:auto;" 
421
|-
422
| <span id='ZEqnNum683915'></span> <math>{\left(\boldsymbol{b}^R\right)}^{n+1}={\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^R}{\left({\phi }_n^R\right)}^{n+1}=</math><math>\frac{1}{\Delta t}{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^R}\left({\phi }^n-\right. </math><math>\left. {\phi }^{n-1}\right)</math>
423
|}
424
| style="width: 5px;text-align: right;white-space: nowrap;" | (32)
425
|}
426
427
and  <math>{\Gamma }^R</math> represent the outlet Boundary condition and has been assume to be vertical.  Introducing Eq. <span id='cite-ZEqnNum683915'></span>[[#ZEqnNum683915|(32)]] into Eq. <span id='cite-ZEqnNum421098'></span>[[#ZEqnNum421098|(30)]] we get:
428
429
{| class="formulaSCP" style="width: 100%; text-align: center;" 
430
|-
431
| 
432
{| style="text-align: center; margin:auto;" 
433
|-
434
| <span id='ZEqnNum947097'></span> <math>\left(\overline{\overline{\boldsymbol{L}}}+\frac{12}{g\Delta t^2+6\kappa (\boldsymbol{x)}\Delta t}{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}+\right. </math><math>\left. \frac{c}{\Delta t}{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^R}\right){\phi }^{n+1}=</math><math>{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}\left(\frac{12}{g\Delta t^2+6\kappa (\boldsymbol{x)}\Delta t}\left(2{\phi }^n-\right. \right. </math><math>\left. \left. {\phi }^{n-1}\right)\right)-{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^{Z_0}}\left(\frac{10g\Delta t}{g\Delta t+6\kappa (\boldsymbol{x)}}{\left({\phi }_z^{Z_0}\right)}^n+\right. </math><math>\left. \left(\frac{g\Delta t-6\kappa (\boldsymbol{x)}}{g\Delta t+6\kappa (\boldsymbol{x)}}\right){\left({\phi }_z^{Z_0}\right)}^{n-1}\right)+</math><math>\frac{c}{\Delta t}{\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^R}{\phi }^n+</math><math>{\left(\boldsymbol{b}^B\right)}^{n+1}</math>
435
|}
436
| style="width: 5px;text-align: right;white-space: nowrap;" | (33)
437
|}
438
439
A strong coupling between the Sommerfeld radiation condition and the Laplace equation has been defined, as we did with the free surface in the previously. Then the boundary condition is integrated within the system matrix, avoiding iterating among the equations.
440
441
Despite of the simplicity of the radiation condition used, we found that its performance of good enough for the purpose of this work, and there is no need of using more sophisticated radiation conditions.
442
443
==3.4 Body boundary condition==
444
445
The boundary condition to be imposed over the surface of the bodies is given by Eq. <span id='cite-ZEqnNum486242'></span>[[#ZEqnNum486242|(11)]]. The movements of the bodies are assumed to be small enough so the computational domain can remind steady, as well as the normals to be bodies’ surface. Then the term  <math>\boldsymbol{b}_{}^B</math> will be calculated by:
446
447
{| class="formulaSCP" style="width: 100%; text-align: center;" 
448
|-
449
| 
450
{| style="text-align: center; margin:auto;" 
451
|-
452
| <span id='ZEqnNum991890'></span> <math>{\left(\boldsymbol{b}^B\right)}^{n+1}={\overline{\overline{\boldsymbol{M}}}}_{{\Gamma }^B}{\left({\phi }_n^B\right)}^{n+1}</math>
453
|}
454
| style="width: 5px;text-align: right;white-space: nowrap;" | (34)
455
|}
456
457
==3.5 Multi-body dynamics==
458
459
Once the velocity potential has been obtained, the pressure at any point can be calculated from:
460
461
{| class="formulaSCP" style="width: 100%; text-align: center;" 
462
|-
463
| 
464
{| style="text-align: center; margin:auto;" 
465
|-
466
| <span id='ZEqnNum826879'></span> <math>P=-\rho gz-\rho {\partial }_t\varphi </math>
467
|}
468
| style="width: 5px;text-align: right;white-space: nowrap;" | (35)
469
|}
470
471
Eq. <span id='cite-ZEqnNum826879'></span>[[#ZEqnNum826879|(35)]] requires estimating the value of  <math>{\partial }_t\varphi </math> . The same fourth order finite difference scheme that has been used for the free surface elevation is used here:
472
473
{| class="formulaSCP" style="width: 100%; text-align: center;" 
474
|-
475
| 
476
{| style="text-align: center; margin:auto;" 
477
|-
478
| <math>P^{n+1}=-\rho gz-\frac{\rho }{\Delta t}\left(\frac{25}{12}{\varphi }^{n+1}-\right. </math><math>\left. 4{\varphi }^n+3{\varphi }^{n-1}-\frac{4}{3}{\varphi }^{n-2}+\right. </math><math>\left. \frac{1}{4}{\varphi }^{n-3}\right)</math>
479
|}
480
| style="width: 5px;text-align: right;white-space: nowrap;" | (36)
481
|}
482
483
Integrating the pressure over the bodies’ surface, the resulting forces and moments are obtained. On the other hand, the bodies dynamics is given by the equation of motion:
484
485
{| class="formulaSCP" style="width: 100%; text-align: center;" 
486
|-
487
| 
488
{| style="text-align: center; margin:auto;" 
489
|-
490
| <span id='ZEqnNum880887'></span> <math>\overline{\overline{M}}\boldsymbol{X}_{tt}+\overline{\overline{K}}\boldsymbol{X}=</math><math>\boldsymbol{F}</math>
491
|}
492
| style="width: 5px;text-align: right;white-space: nowrap;" | (37)
493
|}
494
495
where  <math>\overline{\overline{M}}</math> is the mass matrix of te multi-body system;  <math>\overline{\overline{K}}</math> is the hydrostatic restoring coefficient matrix of the multi-body system;  <math>\boldsymbol{F}</math> is the hydrodynamic forces induced over the bodies plus any other external forces; and  <math>\boldsymbol{X}</math> represent the movements of the six degrees of freedom of each body.
496
497
In the specific case where the bodies are fixed, only refracted waves are calculated and the linear system given in Eq. <span id='cite-ZEqnNum947097'></span>[[#ZEqnNum947097|(33)]] is to be solved just once per time step. However, when solving the body dynamics along with the wave problem requires an iterative procedure since interaction between the waves and the movements of the structure exist, giving birth to waves radiated by the bodies.
498
499
In order to solve Eq.<span id='cite-ZEqnNum880887'></span>[[#ZEqnNum880887|(37)]], we use a implicit Newmark´s average acceleration method:
500
501
{| class="formulaSCP" style="width: 100%; text-align: center;" 
502
|-
503
| 
504
{| style="text-align: center; margin:auto;" 
505
|-
506
| <span id='ZEqnNum746446'></span> <math>\boldsymbol{X}_{tt}^{n+1}={\overline{\overline{M}}}^{-1}(\boldsymbol{F}^{n+1}-</math><math>\overline{\overline{K}}\boldsymbol{X}^{n+1})</math>
507
|}
508
| style="width: 5px;text-align: right;white-space: nowrap;" | (38)
509
|}
510
511
{| class="formulaSCP" style="width: 100%; text-align: center;" 
512
|-
513
| 
514
{| style="text-align: center; margin:auto;" 
515
|-
516
| <span id='ZEqnNum371600'></span> <math>\boldsymbol{X}_t^{n+1}=\boldsymbol{X}_t^n+\Delta t(\frac{1}{2}\boldsymbol{X}_{tt}^n+</math><math>\frac{1}{2}\boldsymbol{X}_{tt}^{n+1})</math>
517
|}
518
| style="width: 5px;text-align: right;white-space: nowrap;" | (39)
519
|}
520
521
{| class="formulaSCP" style="width: 100%; text-align: center;" 
522
|-
523
| 
524
{| style="text-align: center; margin:auto;" 
525
|-
526
| <span id='ZEqnNum826243'></span> <math>\boldsymbol{X}_{}^{n+1}=\boldsymbol{X}_{}^n+\Delta t\boldsymbol{X}_t^n+</math><math>\frac{\Delta t^2}{2}(\frac{1}{2}\boldsymbol{X}_{tt}^n+</math><math>\frac{1}{2}\boldsymbol{X}_{tt}^{n+1})</math>
527
|}
528
| style="width: 5px;text-align: right;white-space: nowrap;" | (40)
529
|}
530
531
Within each time step the systems of Eqs.<span id='cite-ZEqnNum746446'></span>[[#ZEqnNum746446|(38)]]-<span id='cite-ZEqnNum826243'></span>[[#ZEqnNum826243|(40)]] are solved iteratively along with Eq.<span id='cite-ZEqnNum947097'></span>[[#ZEqnNum947097|(33)]]. This requires predicting the body velocities by solving Eq.<span id='cite-ZEqnNum371600'></span>[[#ZEqnNum371600|(39)]], introducing this velocities into Eq.<span id='cite-ZEqnNum991890'></span>[[#ZEqnNum991890|(34)]], solving the linear system in Eq. <span id='cite-ZEqnNum947097'></span>[[#ZEqnNum947097|(33)]], introducing the pressure forces into eq.<span id='cite-ZEqnNum880887'></span>[[#ZEqnNum880887|(37)]], and repeating the process until convergence is reached. In order to accelerate convergence, we used the secant method for predicting the bodies’ velocities and positions.
532
533
The algorithm implemented also allows considering non-linear external forces acting on the bodies such as mooring forces. In this implementation they are evaluated for every iteration of the solver and added to the right hand side of Eq. <span id='cite-ZEqnNum880887'></span>[[#ZEqnNum880887|(37)]].
534
535
==4. Solver acceleration==
536
537
Most of the computational effort of the proposed numerical algorithm is spent in solving the linear system given in Eq. <span id='cite-ZEqnNum947097'></span>[[#ZEqnNum947097|(33)]]. Therefore, our main focused to reduce the computational time is speeding up the linear solver resolution. In order to do so, two techniques, that can be used combined, have been undertaken: the use of deflated solver, and the use of parallel computing in graphic processing units.
538
539
==4.1 Deflated conjugate gradient==
540
541
Deflation works by considering constant approximations on coarse sub-domains. This piecewise constant approximations are associated to the low frequencies eigenmodes of the solution, which are also the slow convergence modes [<span id='cite-_Ref330368235'></span>[[#_Ref330368235|22]],<span id='cite-_Ref330624548'></span>[[#_Ref330624548|23]]]. Then, these slow modes can be quickly approximated by solving a small linear system of equations, which can be incorporated to the traditional preconditioned iterative solvers in order to accelerate the convergence of the solution.
542
543
<span id='_Ref330368235'></span><span id='_Ref330624548'></span>The first step is to divide the domain into a set of coarse sub-domains that will be capable of capturing the slow modes. Several techniques have been developed for this purpose [<span id='cite-22'></span>[[#22|22]],<span id='cite-23'></span>[[#23|23]]]. The most commonly techniques are the using seed-points and the advancing front technique. The former use prescribed seed-points and then sub-domains are built by associating points to seeds based on a distance criterion. The latter uses the advancing from method, where points are associated to a central point based of neighbouring preference, and once a number of points is reached, the sub-domain will be considered filled, and the next point will be used as the following central point.
544
545
The seed-points technique requires prescribing the seeds beforehand, and the advancing front requires a number of refinements to achieve a level of reliability. In this work, the technique used is slightly different to the advancing front. Our technique is also based on neighbouring criteria, but instead of prescribing a number of nodes within each sub-domain, we prescribed the maximum level of neighbouring “L”. The procedure goes as follows:
546
547
Step 0: Assigned level L+1 to all nodes (nodes will accept only lower levels when they are offered)
548
549
Step 1: Start building sub-domain 0: offer level 0 to the first node of the mesh. It will become node (sub-domain, level)=(0,0)
550
551
Step 2: Identify neighbours of node (0,0) and offer them level 1: (0,1)
552
553
Step 3: Identify neighbours of nodes (0,1), and offer them level 2: (0,2).
554
555
Step 4: The procedure is repeated until the prescribed level “L” is reached.
556
557
Step 5: The next node in the mesh with level L+1 is used to start building zone 1, and it is offered level 0, becoming a node (1,0).
558
559
Step 6: Identify neighbours of node (1,0) and offer them level 1: (1,1) (Notice that some (0,L) nodes might  become (1,1)).
560
561
Step 7: Identify neighbours of nodes (1,1), and offer them level 2: (1,2). (Notice that some (0,L) or (0,L-1) nodes might  become (1,2)).
562
563
Step 8: The procedure is repeated until the prescribed level “L” is reached (1,L).
564
565
Step 9: Repeat Steps 5-8 until there is no node with level L+1.
566
567
At the end of the previous procedure, all nodes will be denoted with the coordinate (R,L), representing the sub-domain and level within its sub-domain. It is guaranteed that any node cannot have a lower level in a different sub-domain. Moreover, the higher the prescribed level, the lower the number of sub-domains created. <span id='cite-_Ref330458842'></span>[[#_Ref330458842|Figure 1]] shows a domain decomposition obtained using the aforementioned algorithm. Notice that the level at the sub-domain boundaries is the minimum possible.
568
569
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
570
 [[Image:draft_García-Espinosa_946341310-image113.png|282px]] </div>
571
572
<span id='_Ref330458842'></span><div id="_Ref317660250" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
573
<span style="text-align: center; font-size: 75%;">'''Figure 1''': Sub-domain decomposition using the neighbouring level algorithm.</span></div>
574
575
Although the previous algorithm provides good results, it can be improved by using it twice. Let’s say that in a first round, instead of using the prescribed level L, it is used the prescribed level 2L. A first decomposition is found with a lower number of sub-domains and twice the number of levels. Then, in a second round, the procedure is repeated using level L as the highest possible and starting with those nodes of level 2L to start building new sub-domains, without deleting the previous ones. <span id='cite-_Ref330458877'></span>[[#_Ref330458877|Figure 2]] shows the sub-domain decomposition obtained using the two rounds technique. The first one shows the decomposition at level 2L, and the second shows the decomposition at level L starting of the first decomposition at level 2L. Notice that the level at the sub-domains boundaries is lower or equal than the prescribed level L, and always minimum respect to any central node (node of level zero).
576
577
 [[Image:draft_García-Espinosa_946341310-image114.png|600px]]
578
579
<span id='_Ref330458877'></span><div id="_Ref317660416" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
580
<span style="text-align: center; font-size: 75%;">'''Figure 2:''' Subdomain decomposition using the two rounds neighbouring level algorithm. (a): decomposition after first round. (b): decomposition after second round.</span></div>
581
582
The recommended number of sub-domains might depend on the specific case under study. Usually in the order of hundred is a recommended value. However, in our specific case, the matrix of the linear system to be solved remains the same during the calculation, so that the sub-domain decompositions have to be carried out just once.
583
584
The deflated system has to be solved every iteration of the solver. Therefore, and since in our case the deflated matrix will remain the same, the inverse of the deflated matrix is calculated once, so that the resolution of the deflated system in each iteration is substituted by a matrix vector multiplication.
585
586
==4.2 GPU acceleration==
587
588
Pushed by the videogame industry, graphic processing units are achieving higher and higher computational performance. Therefore, their use for heavy computations is more extended every day (see [<span id='cite-24'></span>[[#24|24]]] for instance).
589
590
The implementation done for this work is based on the well-known CUDA, a parallel computing platform and programming model invented by NVIDIA, for speeding up all the operations carried out by the iterative solver. The linear algebra library provided by Nvidia (cublas) is used to performed dot product operations. The sparse matrix vector multiplication is carried out using the kernel proposed in [<span id='cite-25'></span>[[#25|25]]]. Regarding the matrix vector operation to be carried out in the deflated conjugate gradient, a regular kernel has been implemented.
591
592
For the purpose of this work, a deflated and non-deflated preconditioned conjugate gradient (CG) algorithm has been implemented in CUDA using cublas and cusparse libraries. A sparse approximate inverse (SPAI) preconditioner will be used. An incomplete LU decomposition (ILU) preconditioner was also tested using the sparse lower and upper triangular solvers provided in the cusparse library. However, in our specific case, the performance was poor even when compared to a diagonal preconditioner. Therefore we will omit the use of the ILU preconditioner when computing in GPU.
593
594
Let’s remind that either preconditioner is calculated just once at the beginning of the simulation since the matrix system remains the same at all times. Then, computational time invested in calculating the preconditioner can be vanished when compared to the total time spent in the linear solver along the whole simulation.
595
596
==5. Numerical results==
597
598
==5.1 Waves refracted by a vertical circular cylinder==
599
600
In order to prove the efficiency of the proposed numerical schemes, we will solve the problem of a monochromatic wave interacting with a fix bottom mounted circular cylinder. We have chosen this case study because exist an analytical solution to this problem. This analytical solution was found by McCamy and Fuchs in 1954 [<span id='cite-26'></span>[[#26|26]]]. The potential for a monochromatic wave travelling along the OX axis in cylindrical coordinates is given by:
601
602
{| class="formulaSCP" style="width: 100%; text-align: center;" 
603
|-
604
| 
605
{| style="text-align: center; margin:auto;" 
606
|-
607
| <span id='ZEqnNum236625'></span> <math>{\phi }^I=Re\left\{\frac{iAg}{\omega }\frac{cosh\left(k(H+z)\right)}{cosh\left(kH\right)}\left[\sum_{m\geq 0}{\epsilon }_mJ_m(kr)cos(m\theta )\right]exp(i\omega t)\right\}</math>
608
|}
609
| style="width: 5px;text-align: right;white-space: nowrap;" | (41)
610
|}
611
612
where  <math display="inline">\left(r,\theta ,z\right)</math> are the cylindrical coordinates;  <math>A</math> is the amplitude of the wave;  <math>\omega </math> is the wave frequency;  <math display="inline">H</math> is the water depth;  <math>J_m</math> are the Bessel functions of the first kind; and   <math>{\epsilon }_m=1</math> if   <math>m=0</math> , and  <math>{\epsilon }_m=2{\left(-i\right)}^m</math> if  <math>m>0</math> . The scattered waves potential is given by:
613
614
{| class="formulaSCP" style="width: 100%; text-align: center;" 
615
|-
616
| 
617
{| style="text-align: center; margin:auto;" 
618
|-
619
| <span id='ZEqnNum606888'></span> <math>{\phi }^S=Re\left\{\frac{iAg}{\omega }\frac{cosh\left(k(H+z)\right)}{cosh\left(kH\right)}\left[\sum_{m\geq 0}-\right. \right. </math><math>\left. \left. {\epsilon }_m\frac{J_m^'(kR)}{H_m^{\left(2\right)}{}^'(kR)}H_m^{\left(2\right)}(kr)cos(m\theta )\right]exp(i\omega t)\right\}</math>
620
|}
621
| style="width: 5px;text-align: right;white-space: nowrap;" | (42)
622
|}
623
624
where  <math display="inline">\left({}'\right)</math> denotes derivatives respect to the argument;  <math>R</math> is the radius of the cylinder; and  <math>H_m^{\left(2\right)}</math> are the Hankel function of the second kind. Summing up Eqs. <span id='cite-ZEqnNum236625'></span>[[#ZEqnNum236625|(41)]] and <span id='cite-ZEqnNum606888'></span>[[#ZEqnNum606888|(42)]], we obtain the analytical solution to the wave scattering by vertical circular cylinder problem.
625
626
{| class="formulaSCP" style="width: 100%; text-align: center;" 
627
|-
628
| 
629
{| style="text-align: center; margin:auto;" 
630
|-
631
| <math>\phi =Re\left\{\frac{iAg}{\omega }\frac{cosh\left(k(H+z)\right)}{cosh\left(kH\right)}\left[\sum_{m\geq 0}{\epsilon }_m\left(J_m(kr)-\right. \right. \right. </math><math>\left. \left. \left. \frac{J_m^'(kR)}{H_m^{\left(2\right)}{}^'(kR)}H_m^{\left(2\right)}(kr)\right)cos(m\theta )\right]exp(i\omega t)\right\}</math>
632
|}
633
| style="width: 5px;text-align: right;white-space: nowrap;" | (43)
634
|}
635
636
The pressure value at any point is obtained by Eq.<span id='cite-ZEqnNum826879'></span>[[#ZEqnNum826879|(35)]]. We can further decompose the pressure into the hydrostatic pressure and the pressure induced by the velocity potential <math display="inline">P^{\phi }=-\rho {\partial }_t{\phi }^1</math> , which is given by:
637
638
{| class="formulaSCP" style="width: 100%; text-align: center;" 
639
|-
640
| 
641
{| style="text-align: center; margin:auto;" 
642
|-
643
| <math>P^{\phi }=Re\left\{A\rho g\frac{cosh\left(k(H+z)\right)}{cosh\left(kH\right)}\left[\sum_{m\geq 0}{\epsilon }_m\left(J_m(kr)-\right. \right. \right. </math><math>\left. \left. \left. \frac{J_m{}'(kR)}{H_m^{\left(2\right)}{}'(kR)}H_m^{\left(2\right)}(kr)\right)cos(m\theta )\right]exp(i\omega t)\right\}</math>
644
|}
645
| style="width: 5px;text-align: right;white-space: nowrap;" | (44)
646
|}
647
648
The horizontal force induced over the cylinder is obtained by integration of  <math>P^{\phi }</math> over the cylinder. This force is given by the following equation:
649
650
{| class="formulaSCP" style="width: 100%; text-align: center;" 
651
|-
652
| 
653
{| style="text-align: center; margin:auto;" 
654
|-
655
| <math>F_x=Re\left\{2iAR\rho g\pi \frac{tanh\left(kH\right)}{k}\left(J_1(kR)-\right. \right. </math><math>\left. \left. \frac{J_1{}'(kR)}{H_1^{\left(2\right)}{}'(kR)}H_1^{\left(2\right)}(kR)\right)exp(i\omega t)\right\}</math>
656
|}
657
| style="width: 5px;text-align: right;white-space: nowrap;" | (45)
658
|}
659
660
Next we compare numerical results obtained by the analytical solution with numerical results obtained by our FEM schemes for the specific case of  <math>R=1\mbox{ }m</math> ,  <math>H=1\mbox{ }m</math> ,  <math>A=0.1\mbox{ }m</math> ,  <math>L=2\mbox{ }m</math> . Using <math display="inline">\rho =1025\mbox{ }kg/m^3</math> ,  <math display="inline">g=9.81\mbox{ }m/s^2</math> and by mean of the dispersion relation for first order waves, we obtain the frequency value  <math>\omega =\sqrt{g\pi tanh(\pi )}=\mbox{5}\mbox{.5411}</math> rad/s, and the wave period T = 1.1339s.
661
662
The simulation is carried out using a circular domain with a radius of 6 meters. The mesh size is set to 0.1 m in an inner volume within a radius of 2 meters. In the outer volume, the mesh size grows smoothly up to 0.5meters.
663
664
<span id='cite-_Ref330458925'></span>[[#_Ref330458925|Figure 3]] compares the contour lines of the free surface elevation at any time  <math>t=nT</math> . Notice that the FEM solution mostly lie over the analytical solution.
665
666
<span id='cite-_Ref330458941'></span>[[#_Ref330458941|Figure 4]] compares the pressure distribution over the cylinder obtained by the analytical solution and the FEM solution. Both pressure distributions are obtained using the same colour scale, with a maximum value of 950Pa and a minimum of -1700Pa.
667
668
Integration of the x component of  <math>P^{\phi }</math> over the cylinder provides the Horizontal force induced over the cylinder. This force is given by the following equation:
669
670
{| class="formulaSCP" style="width: 100%; text-align: center;" 
671
|-
672
| 
673
{| style="text-align: center; margin:auto;" 
674
|-
675
| <math>F_x=Re\left\{2iAR\rho g\pi \frac{tanh\left(kH\right)}{k}\left(J_1(kR)-\right. \right. </math><math>\left. \left. \frac{J_1{}'(kR)}{H_1^{\left(2\right)}{}'(kR)}H_1^{\left(2\right)}(kR)\right)exp(i\omega t)\right\}</math>
676
|}
677
| style="width: 5px;text-align: right;white-space: nowrap;" | (46)
678
|}
679
680
<span id='cite-_Ref330458974'></span>[[#_Ref330458974|Figure 5]] compares the force induced over the cylinder obtained by the analytical solution and FEM. It can be seen that the forces obtained in both ways are quite close to each other.
681
682
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
683
 [[Image:draft_García-Espinosa_946341310-image142.png|408px]] </div>
684
685
<span id='_Ref330458925'></span><div id="_Ref278014512" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
686
'''Figure 3: '''Contour lines of free surface elevation at time =15s. Analytical: solid line; FEM:dot line.</div>
687
688
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
689
 [[Image:draft_García-Espinosa_946341310-image143.png|348px]] </div>
690
691
<span id='_Ref330458941'></span><div id="_Ref278014587" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
692
'''Figure 4''':''' '''Pressure induced on the cylinder by the velocity potential at time=15s. Comparison between analytical and FEM results.</div>
693
694
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
695
 [[Image:draft_García-Espinosa_946341310-image144.png|282px]] </div>
696
697
<span id='_Ref330458974'></span><div id="_Ref278014671" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
698
'''Figure 5''':''' '''Horizontal force induced over the cylinder. Analytical (solid line) and FEM (circle).</div>
699
700
==5.2 Freely floating tension leg platform (TLP)==
701
702
In this section we analyze the seakeeping behaviour of a freely floating tension leg platform (TLP). The platform used is the ISSC TLP [<span id='cite-27'></span>[[#27|27]]]. The mass is obtained internally to equal the displacement of the platform. The gravity centre position and radii of inertia are provided in <span id='cite-_Ref330459195'></span>[[#_Ref330459195|Table 1]]. <span id='cite-_Ref330459236'></span>[[#_Ref330459236|Figure 6]] shows the mesh used for the present case study.
703
704
<div id="_Ref330459195" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
705
<span style="text-align: center; font-size: 75%;">'''Table 1: '''ISSC TLP particulars</span></div>
706
707
{| style="margin: 1em auto 0.1em auto;border-collapse: collapse;" 
708
|-
709
|  style="border: 1pt solid black;text-align: center;"|XG (m)
710
|  style="border: 1pt solid black;text-align: center;"|0
711
|-
712
|  style="border: 1pt solid black;text-align: center;"|YG (m)
713
|  style="border: 1pt solid black;text-align: center;"|0
714
|-
715
|  style="border: 1pt solid black;text-align: center;"|ZG (m)
716
|  style="border: 1pt solid black;text-align: center;"|3
717
|-
718
|  style="border: 1pt solid black;text-align: center;"|Ixx/Mass (m<sup>2</sup>)
719
|  style="border: 1pt solid black;text-align: center;"|38.876
720
|-
721
|  style="border: 1pt solid black;text-align: center;"|Iyy/Mass (m<sup>2</sup>)
722
|  style="border: 1pt solid black;text-align: center;"|38.876
723
|-
724
|  style="border: 1pt solid black;text-align: center;"|Izz/Mass (m<sup>2</sup>)
725
|  style="border: 1pt solid black;text-align: center;"|42.420
726
|}
727
728
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
729
 [[Image:draft_García-Espinosa_946341310-image145.png|300px]] </div>
730
731
<div id="_Ref330459236" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
732
<span style="text-align: center; font-size: 75%;">'''Figure 6''': ISSC TLP and free surface meshes.</span></div>
733
734
The gravity used is  <math>\mbox{g=9}\mbox{.80665}\mbox{ }{\mbox{m/s}}^\mbox{2}</math> , the water density used is  <math>\rho \mbox{=1025}\mbox{ }{\mbox{kg/m}}^\mbox{3}</math> , and water depth is assume to be infinite. The Hydrostatic tensor  <math display="inline">\overline{\overline{\boldsymbol{K}}}</math> is calculated by the corresponding boundary integrals.
735
736
We are interested in how the body moves when excited by a regular wave. In this specific case where the only excitation is the wave, the TLP is expected to respond harmonically with the same frequency that the frequency of the incident wave. However, since the method developed solves the problem in the time domain, initial conditions will be important.
737
738
Simulations were carried out for periods ranging between eight and fifteen seconds for three different wave heading. <span id='cite-_Ref330459270'></span>[[#_Ref330459270|Figure 7]] compares the response amplitude operators (RAOs) obtained by the present FEM model and RAOs obtained by the well known program WAMIT [<span id='cite-28'></span>[[#28|28]]], which is based on the BEM and solves in the frequency domain. The obtained results show very good agreement between both solvers.
739
740
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
741
 [[Image:draft_García-Espinosa_946341310-image149.png|600px]] </div>
742
743
<span id='_Ref330459270'></span><div id="_Ref317760106" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
744
'''Figure 7:''' Response amplitude operator for freely floating TLP. Circles: WAMIT; triangles FEM.</div>
745
746
==5.3 Seakeeping of a GVA 4000 Semisubmersible platform==
747
748
<span id='_Ref319314028'></span>Next we carry out comparison, between experimental data [<span id='cite-29'></span>[[#29|29]]] and numerical results obtained via the method presented in this work, regarding the seakeeping behaviour of the GVA 4000 semisubmersible platform. The results to be compared are the heave and pitch response amplitude operators of the GVA 400 in heading seas, with a range of wave periods between 6 and 32 seconds.
749
750
The platform displacement is 25940 tonnes. The center of gravity is located 21.35 m above the keel, and the horizontal position corresponds to the geometric center of the platform. The radii of inertia are rxx=30.40 m, ryy=31.06 m, and rzz=37.54 m. The geometry of the GVA 4000 can be found in [<span id='cite-_Ref319314028'></span>[[#_Ref319314028|29]]].
751
752
Based on [<span id='cite-_Ref319314028'></span>[[#_Ref319314028|29]]], the model tests were carried out with the surge movement constraint by the action of a pre-stressed spring whose mission is to keep in place the structure during the testing. Besides, this spring creates also a pitching moment. Therefore, the pitch movement will be influenced not just by the waves, but also by the surge movement and the spring.
753
754
Since we have no data regarding the mechanism used by the model basin to keep in place the platform during the tests, we cannot include it in the simulation. Instead, simulations have been carried out in two cases: no surge and free surge. <span id='cite-_Ref330459298'></span>[[#_Ref330459298|Figure 8]] compares the experimental results and numerical FEM results. The experimental results lay within the numerical results obtained for free surge and no surge cases as expected.
755
756
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
757
 [[Image:draft_García-Espinosa_946341310-image150.png|600px]] </div>
758
759
<div id="_Ref330459298" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
760
<span style="text-align: center; font-size: 75%;">'''Figure 8: '''Heave and pitch''' '''response amplitude operators for the GVA 4000. Dots: experimental data. Solid line: FEM.</span></div>
761
762
==5.4 Deflated solver==
763
764
Solver deflation is gaining popularity as a way to improve convergence in linear solvers, and therefore in order to reduce solver iteration and CPU time. Deflation acts by solving in a fast and coarse manner eigenmodes associated with the lowest eigenvalues [<span id='cite-_Ref330368235'></span>[[#_Ref330368235|22]]]. Therefore, it will improve convergence better in those problems with a larger range of eigenmodes, such as flows in pipes.
765
766
In order to check the performance of deflated solver in our problems, simulations using the ISSC TLP platform have been carried out using five different meshes. For each case, different levels of deflation have been used, and they have been compared to a non-deflated case. <span id='cite-_Ref330369024'></span>[[#_Ref330369024|Table 2]] provides the particulars of each case.
767
768
<div id="_Ref330369024" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
769
<span style="text-align: center; font-size: 75%;">'''Table 2: '''Particular of each case</span></div>
770
771
{| style="margin: 1em auto 0.1em auto;border-collapse: collapse;" 
772
|-
773
|  style="border: 1pt solid black;text-align: center;"|
774
|  style="border: 1pt solid black;text-align: center;"|Case 1
775
|  style="border: 1pt solid black;text-align: center;"|Case 2
776
|  style="border: 1pt solid black;text-align: center;"|Case 3
777
|  style="border: 1pt solid black;text-align: center;"|Case 4
778
|  style="border: 1pt solid black;text-align: center;"|Case 5
779
|-
780
|  style="border: 1pt solid black;text-align: center;"|Number of Nodes
781
|  style="border: 1pt solid black;text-align: center;"|17804
782
|  style="border: 1pt solid black;text-align: center;"|51333
783
|  style="border: 1pt solid black;text-align: center;"|153758
784
|  style="border: 1pt solid black;text-align: center;"|459538
785
|  style="border: 1pt solid black;text-align: center;"|913149
786
|-
787
|  style="border: 1pt solid black;text-align: center;"|Number of Elements
788
|  style="border: 1pt solid black;text-align: center;"|101572
789
|  style="border: 1pt solid black;text-align: center;"|292705
790
|  style="border: 1pt solid black;text-align: center;"|792372
791
|  style="border: 1pt solid black;text-align: center;"|2335374
792
|  style="border: 1pt solid black;text-align: center;"|4640638
793
|-
794
|  style="border: 1pt solid black;text-align: center;"|h (m)
795
|  style="border: 1pt solid black;text-align: center;"|4
796
|  style="border: 1pt solid black;text-align: center;"|2
797
|  style="border: 1pt solid black;text-align: center;"|0.5
798
|  style="border: 1pt solid black;text-align: center;"|0.35
799
|  style="border: 1pt solid black;text-align: center;"|0.25
800
|-
801
|  style="border: 1pt solid black;text-align: center;"|Δt (s)
802
|  style="border: 1pt solid black;text-align: center;"|0.75
803
|  style="border: 1pt solid black;text-align: center;"|0.5
804
|  style="border: 1pt solid black;text-align: center;"|0.1
805
|  style="border: 1pt solid black;text-align: center;"|0.075
806
|  style="border: 1pt solid black;text-align: center;"|0.05
807
|}
808
809
Comparisons are made using the conjugate gradient along with an incomplete LU preconditioner. In the case of deflated solver, different levels of neighbouring have been used, resulting in different number of subdomains in each case. Once the deflation space is built, the resulting deflated matrix is inverted. This inversion is carried out just once since the system matrix remains unchanged during the simulation. In all cases, the same CPU has been used.
810
811
<span id='cite-_Ref330382824'></span>[[#_Ref330382824|Figure 9]] shows the reduction in iterations for each case as the number of subdomains changes. <span id='cite-_Ref330370512'></span>[[#_Ref330370512|Table 3]], <span id='cite-_Ref330370513'></span>[[#_Ref330370513|Table 4]],<span id='cite-_Ref330370515'></span>[[#_Ref330370515|Table 5]], <span id='cite-_Ref330370517'></span>[[#_Ref330370517|Table 6]] and <span id='cite-_Ref330370518'></span>[[#_Ref330370518|Table 7]] shows the average number of iterations and speed up respect to the non-deflated case. It can be observed that the number of iterations decreases as the dimension of the deflated subspace increases. This reduction in the number of iteration when using an ILU preconditioner indicates that the proposed technique for building subdomains is performing well.
812
813
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
814
 [[Image:draft_García-Espinosa_946341310-image151.png|300px]] </div>
815
816
<div id="_Ref330382824" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
817
<span style="text-align: center; font-size: 75%;">'''Figure 9: '''Percentage of iterations versus ratio of number of nodes to number of subdomains.</span></div>
818
819
However, when using deflated solver, a few operations are added to each solver iteration. Hence reducing iterations is not a synonym of reducing CPU time. Based on the results obtained, it can be said that the larger the system, the larger the speed up that can be obtained, and also the larger the number of subdomains must be. However, care must be taken because a dimension of the deflated subspace might end up in increasing the CPU time. Moreover, for smaller cases, deflation might even not be capable of speeding up at all.
820
821
<div id="_Ref330370512" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
822
<span style="text-align: center; font-size: 75%;">'''Table 3: '''Comparative among deflated solvers and non-deflated</span></div>
823
824
{| style="margin: 1em auto 0.1em auto;border-collapse: collapse;" 
825
|-
826
|  colspan='4'  style="border: 1pt solid black;text-align: center;"|Case 1: Number of nodes = 17804
827
|-
828
|  style="border: 1pt solid black;text-align: center;"|Neighbouring level
829
|  style="border: 1pt solid black;text-align: center;"|Number of Sub-domains
830
|  style="border: 1pt solid black;text-align: center;"|Average Number Iterations
831
|  style="border: 1pt solid black;text-align: center;"|Speed up
832
|-
833
|  style="border: 1pt solid black;text-align: center;"|2
834
|  style="border: 1pt solid black;text-align: center;"|836
835
|  style="border: 1pt solid black;text-align: center;"|15.89
836
|  style="border: 1pt solid black;text-align: center;"|0.556
837
|-
838
|  style="border: 1pt solid black;text-align: center;"|3
839
|  style="border: 1pt solid black;text-align: center;"|316
840
|  style="border: 1pt solid black;text-align: center;"|18.18
841
|  style="border: 1pt solid black;text-align: center;"|0.963
842
|-
843
|  style="border: 1pt solid black;text-align: center;"|4
844
|  style="border: 1pt solid black;text-align: center;"|174
845
|  style="border: 1pt solid black;text-align: center;"|19.36
846
|  style="border: 1pt solid black;text-align: center;"|0.989
847
|-
848
|  style="border: 1pt solid black;text-align: center;"|5
849
|  style="border: 1pt solid black;text-align: center;"|100
850
|  style="border: 1pt solid black;text-align: center;"|21.34
851
|  style="border: 1pt solid black;text-align: center;"|0.894
852
|-
853
|  style="border: 1pt solid black;text-align: center;"|6
854
|  style="border: 1pt solid black;text-align: center;"|66
855
|  style="border: 1pt solid black;text-align: center;"|22.39
856
|  style="border: 1pt solid black;text-align: center;"|0.871
857
|-
858
|  style="border: 1pt solid black;text-align: center;"|7
859
|  style="border: 1pt solid black;text-align: center;"|49
860
|  style="border: 1pt solid black;text-align: center;"|23.74
861
|  style="border: 1pt solid black;text-align: center;"|0.829
862
|-
863
|  colspan='2'  style="border: 1pt solid black;text-align: center;"|Non-deflated
864
|  style="border: 1pt solid black;text-align: center;"|28.75
865
|  style="border: 1pt solid black;text-align: center;"|1
866
|}
867
868
<div id="_Ref330370513" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
869
<span style="text-align: center; font-size: 75%;">'''Table 4: '''Comparative among deflated solvers and non-deflated</span></div>
870
871
{| style="margin: 1em auto 0.1em auto;border-collapse: collapse;" 
872
|-
873
|  colspan='4'  style="border: 1pt solid black;text-align: center;"|Case 2: Number of nodes = 51333
874
|-
875
|  style="border: 1pt solid black;text-align: center;"|Neighbouring level
876
|  style="border: 1pt solid black;text-align: center;"|Number of Sub-domains
877
|  style="border: 1pt solid black;text-align: center;"|Average Number Iterations
878
|  style="border: 1pt solid black;text-align: center;"|Speed up
879
|-
880
|  style="border: 1pt solid black;text-align: center;"|2
881
|  style="border: 1pt solid black;text-align: center;"|2419
882
|  style="border: 1pt solid black;text-align: center;"|17.34
883
|  style="border: 1pt solid black;text-align: center;"|0.310
884
|-
885
|  style="border: 1pt solid black;text-align: center;"|3
886
|  style="border: 1pt solid black;text-align: center;"|963
887
|  style="border: 1pt solid black;text-align: center;"|20.23
888
|  style="border: 1pt solid black;text-align: center;"|0.908
889
|-
890
|  style="border: 1pt solid black;text-align: center;"|4
891
|  style="border: 1pt solid black;text-align: center;"|506
892
|  style="border: 1pt solid black;text-align: center;"|22.00
893
|  style="border: 1pt solid black;text-align: center;"|1.081
894
|-
895
|  style="border: 1pt solid black;text-align: center;"|5
896
|  style="border: 1pt solid black;text-align: center;"|299
897
|  style="border: 1pt solid black;text-align: center;"|24.15
898
|  style="border: 1pt solid black;text-align: center;"|1.055
899
|-
900
|  style="border: 1pt solid black;text-align: center;"|6
901
|  style="border: 1pt solid black;text-align: center;"|201
902
|  style="border: 1pt solid black;text-align: center;"|25.20
903
|  style="border: 1pt solid black;text-align: center;"|1.023
904
|-
905
|  style="border: 1pt solid black;text-align: center;"|7
906
|  style="border: 1pt solid black;text-align: center;"|146
907
|  style="border: 1pt solid black;text-align: center;"|26.17
908
|  style="border: 1pt solid black;text-align: center;"|0.943
909
|-
910
|  style="border: 1pt solid black;text-align: center;"|8
911
|  style="border: 1pt solid black;text-align: center;"|107
912
|  style="border: 1pt solid black;text-align: center;"|27.77
913
|  style="border: 1pt solid black;text-align: center;"|0.907
914
|-
915
|  style="border: 1pt solid black;text-align: center;"|9
916
|  style="border: 1pt solid black;text-align: center;"|73
917
|  style="border: 1pt solid black;text-align: center;"|29.04
918
|  style="border: 1pt solid black;text-align: center;"|0.889
919
|-
920
|  style="border: 1pt solid black;text-align: center;"|10
921
|  style="border: 1pt solid black;text-align: center;"|59
922
|  style="border: 1pt solid black;text-align: center;"|28.84
923
|  style="border: 1pt solid black;text-align: center;"|0.912
924
|-
925
|  style="border: 1pt solid black;text-align: center;"|11
926
|  style="border: 1pt solid black;text-align: center;"|42
927
|  style="border: 1pt solid black;text-align: center;"|30.36
928
|  style="border: 1pt solid black;text-align: center;"|0.863
929
|-
930
|  style="border: 1pt solid black;text-align: center;"|12
931
|  style="border: 1pt solid black;text-align: center;"|30
932
|  style="border: 1pt solid black;text-align: center;"|32.27
933
|  style="border: 1pt solid black;text-align: center;"|0.789
934
|-
935
|  colspan='2'  style="border: 1pt solid black;text-align: center;"|Non-deflated
936
|  style="border: 1pt solid black;text-align: center;"|38.68
937
|  style="border: 1pt solid black;text-align: center;"|1
938
|}
939
940
<div id="_Ref330370515" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
941
<span style="text-align: center; font-size: 75%;">'''Table 5: C'''omparative among deflated solvers and non-deflated</span></div>
942
943
{| style="margin: 1em auto 0.1em auto;border-collapse: collapse;" 
944
|-
945
|  colspan='4'  style="border: 1pt solid black;text-align: center;"|Case 3: Number of nodes = 153758
946
|-
947
|  style="border: 1pt solid black;text-align: center;"|Neighbouring level
948
|  style="border: 1pt solid black;text-align: center;"|Number of Sub-domains
949
|  style="border: 1pt solid black;text-align: center;"|Average Number Iterations
950
|  style="border: 1pt solid black;text-align: center;"|Speed up
951
|-
952
|  style="border: 1pt solid black;text-align: center;"|4
953
|  style="border: 1pt solid black;text-align: center;"|2101
954
|  style="border: 1pt solid black;text-align: center;"|20.82
955
|  style="border: 1pt solid black;text-align: center;"|0.77
956
|-
957
|  style="border: 1pt solid black;text-align: center;"|5
958
|  style="border: 1pt solid black;text-align: center;"|1153
959
|  style="border: 1pt solid black;text-align: center;"|22.82
960
|  style="border: 1pt solid black;text-align: center;"|1.20
961
|-
962
|  style="border: 1pt solid black;text-align: center;"|6
963
|  style="border: 1pt solid black;text-align: center;"|675
964
|  style="border: 1pt solid black;text-align: center;"|24.71
965
|  style="border: 1pt solid black;text-align: center;"|1.30
966
|-
967
|  style="border: 1pt solid black;text-align: center;"|7
968
|  style="border: 1pt solid black;text-align: center;"|405
969
|  style="border: 1pt solid black;text-align: center;"|28.59
970
|  style="border: 1pt solid black;text-align: center;"|1.17
971
|-
972
|  style="border: 1pt solid black;text-align: center;"|8
973
|  style="border: 1pt solid black;text-align: center;"|243
974
|  style="border: 1pt solid black;text-align: center;"|33.8
975
|  style="border: 1pt solid black;text-align: center;"|1.00
976
|-
977
|  style="border: 1pt solid black;text-align: center;"|9
978
|  style="border: 1pt solid black;text-align: center;"|154
979
|  style="border: 1pt solid black;text-align: center;"|37.5
980
|  style="border: 1pt solid black;text-align: center;"|0.91
981
|-
982
|  style="border: 1pt solid black;text-align: center;"|10
983
|  style="border: 1pt solid black;text-align: center;"|96
984
|  style="border: 1pt solid black;text-align: center;"|42.06
985
|  style="border: 1pt solid black;text-align: center;"|0.82
986
|-
987
|  style="border: 1pt solid black;text-align: center;"|11
988
|  style="border: 1pt solid black;text-align: center;"|60
989
|  style="border: 1pt solid black;text-align: center;"|49.03
990
|  style="border: 1pt solid black;text-align: center;"|0.71
991
|-
992
|  style="border: 1pt solid black;text-align: center;"|12
993
|  style="border: 1pt solid black;text-align: center;"|45
994
|  style="border: 1pt solid black;text-align: center;"|46.83
995
|  style="border: 1pt solid black;text-align: center;"|0.72
996
|-
997
|  colspan='2'  style="border: 1pt solid black;text-align: center;"|Non-deflated
998
|  style="border: 1pt solid black;text-align: center;"|49.53
999
|  style="border: 1pt solid black;text-align: center;"|1
1000
|}
1001
1002
<div id="_Ref330370517" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1003
<span style="text-align: center; font-size: 75%;">'''Table 6: '''Comparative among deflated solvers and non-deflated</span></div>
1004
1005
{| style="margin: 1em auto 0.1em auto;border-collapse: collapse;" 
1006
|-
1007
|  colspan='4'  style="border: 1pt solid black;text-align: center;"|Case 4: Number of nodes = 459538
1008
|-
1009
|  style="border: 1pt solid black;text-align: center;"|Neighbouring level
1010
|  style="border: 1pt solid black;text-align: center;"|Number of Sub-domains
1011
|  style="border: 1pt solid black;text-align: center;"|Average Number Iterations
1012
|  style="border: 1pt solid black;text-align: center;"|Speed up
1013
|-
1014
|  style="border: 1pt solid black;text-align: center;"|6
1015
|  style="border: 1pt solid black;text-align: center;"|1936
1016
|  style="border: 1pt solid black;text-align: center;"|25.46
1017
|  style="border: 1pt solid black;text-align: center;"|1.01
1018
|-
1019
|  style="border: 1pt solid black;text-align: center;"|7
1020
|  style="border: 1pt solid black;text-align: center;"|1128
1021
|  style="border: 1pt solid black;text-align: center;"|25.58
1022
|  style="border: 1pt solid black;text-align: center;"|1.39
1023
|-
1024
|  style="border: 1pt solid black;text-align: center;"|8
1025
|  style="border: 1pt solid black;text-align: center;"|641
1026
|  style="border: 1pt solid black;text-align: center;"|32.66
1027
|  style="border: 1pt solid black;text-align: center;"|1.22
1028
|-
1029
|  style="border: 1pt solid black;text-align: center;"|9
1030
|  style="border: 1pt solid black;text-align: center;"|374
1031
|  style="border: 1pt solid black;text-align: center;"|39.38
1032
|  style="border: 1pt solid black;text-align: center;"|1.03
1033
|-
1034
|  style="border: 1pt solid black;text-align: center;"|10
1035
|  style="border: 1pt solid black;text-align: center;"|232
1036
|  style="border: 1pt solid black;text-align: center;"|42.86
1037
|  style="border: 1pt solid black;text-align: center;"|0.94
1038
|-
1039
|  style="border: 1pt solid black;text-align: center;"|11
1040
|  style="border: 1pt solid black;text-align: center;"|137
1041
|  style="border: 1pt solid black;text-align: center;"|48.90
1042
|  style="border: 1pt solid black;text-align: center;"|0.84
1043
|-
1044
|  style="border: 1pt solid black;text-align: center;"|12
1045
|  style="border: 1pt solid black;text-align: center;"|82
1046
|  style="border: 1pt solid black;text-align: center;"|52.76
1047
|  style="border: 1pt solid black;text-align: center;"|0.76
1048
|-
1049
|  colspan='2'  style="border: 1pt solid black;text-align: center;"|Non-deflated
1050
|  style="border: 1pt solid black;text-align: center;"|60.86
1051
|  style="border: 1pt solid black;text-align: center;"|1
1052
|}
1053
1054
<div id="_Ref330370518" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1055
<span style="text-align: center; font-size: 75%;">'''Table 7: '''Comparative among deflated solvers and non-deflated</span></div>
1056
1057
{| style="margin: 1em auto 0.1em auto;border-collapse: collapse;" 
1058
|-
1059
|  colspan='4'  style="border: 1pt solid black;text-align: center;"|Case 5: Number of nodes = 913149
1060
|-
1061
|  style="border: 1pt solid black;text-align: center;"|Neighbouring level
1062
|  style="border: 1pt solid black;text-align: center;"|Number of Sub-domains
1063
|  style="border: 1pt solid black;text-align: center;"|Average Number Iterations
1064
|  style="border: 1pt solid black;text-align: center;"|Speed up
1065
|-
1066
|  style="border: 1pt solid black;text-align: center;"|6
1067
|  style="border: 1pt solid black;text-align: center;"|3837
1068
|  style="border: 1pt solid black;text-align: center;"|26.70
1069
|  style="border: 1pt solid black;text-align: center;"|0.54
1070
|-
1071
|  style="border: 1pt solid black;text-align: center;"|7
1072
|  style="border: 1pt solid black;text-align: center;"|2229
1073
|  style="border: 1pt solid black;text-align: center;"|29.95
1074
|  style="border: 1pt solid black;text-align: center;"|1.10
1075
|-
1076
|  style="border: 1pt solid black;text-align: center;"|8
1077
|  style="border: 1pt solid black;text-align: center;"|1271
1078
|  style="border: 1pt solid black;text-align: center;"|31.60
1079
|  style="border: 1pt solid black;text-align: center;"|1.40
1080
|-
1081
|  style="border: 1pt solid black;text-align: center;"|9
1082
|  style="border: 1pt solid black;text-align: center;"|717
1083
|  style="border: 1pt solid black;text-align: center;"|39.55
1084
|  style="border: 1pt solid black;text-align: center;"|1.20
1085
|-
1086
|  style="border: 1pt solid black;text-align: center;"|10
1087
|  style="border: 1pt solid black;text-align: center;"|413
1088
|  style="border: 1pt solid black;text-align: center;"|44.55
1089
|  style="border: 1pt solid black;text-align: center;"|1.07
1090
|-
1091
|  style="border: 1pt solid black;text-align: center;"|11
1092
|  style="border: 1pt solid black;text-align: center;"|246
1093
|  style="border: 1pt solid black;text-align: center;"|48.50
1094
|  style="border: 1pt solid black;text-align: center;"|0.99
1095
|-
1096
|  style="border: 1pt solid black;text-align: center;"|12
1097
|  style="border: 1pt solid black;text-align: center;"|147
1098
|  style="border: 1pt solid black;text-align: center;"|56.55
1099
|  style="border: 1pt solid black;text-align: center;"|0.83
1100
|-
1101
|  colspan='2'  style="border: 1pt solid black;text-align: center;"|Non-deflated
1102
|  style="border: 1pt solid black;text-align: center;"|71.85
1103
|  style="border: 1pt solid black;text-align: center;"|1
1104
|}
1105
1106
==5.5 Multi-body simulation.==
1107
1108
In this section we will simulate an array of sixteen freely floating bodies in the presence of a regular wave. The purpose of this simulation is to show that our approach can handle multi-body simulations in a reasonable time. Let’s recall that when solving in the frequency domain, it is required to compute how each body affects all the others. Therefore, the number of interactions will grow with the number of bodies squared, making the computational effort to grow very quickly as the number of bodies increases.
1109
1110
The case study consists of simulating the dynamics of an array of sixteen freely floating cylinders in the presence of a regular wave. Each cylinder has a radius of one meter, and a draft of half meter. The six degrees of freedom are free to move for each single body. Then, since they are freely floating, the mass of each equals the mass of the displaced water. Radii of gyration respect to their own centre of gravity are equal to one. Regarding the incident wave, it has a wave period of two seconds, amplitude of ten centimetres, and the incident direction is 22.5º. The cylinders are placed on a regular pattern and the distance between the centres of adjacent cylinders is three meters. A fifty second simulations is carried out, where the first twenty-five second correspond to an initialization period where the amplitude of the incident wave increases smoothly up to ten centimetres. Absorption starts at a distance of 12 meters from the origin of coordinates.
1111
1112
The case study is simulated with three levels of grid refinement. Computational time spent to solve the linear system of equation in every time step during the simulations were measured and are reported in the next section. <span id='cite-_Ref329162787'></span>[[#_Ref329162787|Table 8]] provides the particulars of the meshes and numerical parameters used, and <span id='cite-_Ref329162537'></span>[[#_Ref329162537|Figure 10]] shows the three different meshes used in this study. <span id='cite-_Ref330459397'></span>[[#_Ref330459397|Figure 11]] shows the free surface elevation at the end of the simulation.
1113
1114
<span id='cite-_Ref330726999'></span>[[#_Ref330726999|Figure 12]] compares the movements of the cylinder located in the upper right corner for the three meshes used. While some difference is found for the coarser mesh, results are very close to cases 2 and 3.
1115
1116
<div id="_Ref329162787" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1117
<span style="text-align: center; font-size: 75%;">'''Table 8: '''Mesh properties and case study numerical parameters</span></div>
1118
1119
{| style="width: 100%;border-collapse: collapse;" 
1120
|-
1121
|  style="border: 1pt solid black;text-align: center;"|
1122
|  style="border: 1pt solid black;text-align: center;"|Number of nodes
1123
|  style="border: 1pt solid black;text-align: center;"|Number of elements
1124
|  style="border: 1pt solid black;text-align: center;"|Characteristic element size (m)
1125
|  style="border: 1pt solid black;text-align: center;"|Time step (s)
1126
|-
1127
|  style="border: 1pt solid black;text-align: center;"|Case 1
1128
|  style="border: 1pt solid black;text-align: center;"|137556
1129
|  style="border: 1pt solid black;text-align: center;"|799665
1130
|  style="border: 1pt solid black;text-align: center;"|0.2
1131
|  style="border: 1pt solid black;text-align: center;"|0.1
1132
|-
1133
|  style="border: 1pt solid black;text-align: center;"|Case 2
1134
|  style="border: 1pt solid black;text-align: center;"|369410
1135
|  style="border: 1pt solid black;text-align: center;"|2152774
1136
|  style="border: 1pt solid black;text-align: center;"|0.1
1137
|  style="border: 1pt solid black;text-align: center;"|0.07
1138
|-
1139
|  style="border: 1pt solid black;text-align: center;"|Case 3
1140
|  style="border: 1pt solid black;text-align: center;"|1181302
1141
|  style="border: 1pt solid black;text-align: center;"|6878083
1142
|  style="border: 1pt solid black;text-align: center;"|0.05
1143
|  style="border: 1pt solid black;text-align: center;"|0.05
1144
|}
1145
1146
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1147
 [[Image:draft_García-Espinosa_946341310-image152.png|270px]] </div>
1148
1149
<div id="_Ref329162537" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1150
<span style="text-align: center; font-size: 75%;">'''Figure 10: '''Multi-body simulation. (a), case 1 mesh; (v) case 2 mesh; (c) case 3 mesh.</span></div>
1151
1152
<div class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1153
''' [[Image:draft_García-Espinosa_946341310-image153.jpeg|306px]] '''</div>
1154
1155
<div id="_Ref330459397" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1156
<span style="text-align: center; font-size: 75%;">'''Figure 11: '''Multi-body simulation: Free surface elevation at time=49.8 seconds.</span></div>
1157
1158
<div id="_Ref330459481" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1159
<span style="text-align: center; font-size: 75%;">''' [[Image:draft_García-Espinosa_946341310-image154.png|600px]] '''</span></div>
1160
1161
<span id='_Ref330726999'></span><div id="_Ref330726988" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1162
<span style="text-align: center; font-size: 75%;">'''Figure 12: '''Multi-body simulation: movements of the body located at the upper right corner. Comparison using different level of mesh refinement.</span></div>
1163
1164
==5.5 GPU solver acceleration.==
1165
1166
We use the previous case study to carry out some speed-ups analyses when using different types of GPU/CPU architecture, as well as using different types of preconditioner. When computing in parallel in the GPU, the sparse approximate inverse (SPAI) preconditioner will be used. When carrying out serial computation in the CPU, the SPAI and incomplete LU decomposition preconditioner will be used. Let’s remind that the matrix system does not change along the simulation. Therefore, preconditioner and deflated matrices are only requested to be computed once. Also, let’s point out that the use of the ILU preconditioner in GPU architectures is not recommended due to its poor parallelization across thousands of threads as required by GPUs to hide memory latency.
1167
1168
In order to compare computational performance, we carried out simulation in four different platforms: two GPU platforms, and two CPU platforms. <span id='cite-_Ref329181937'></span>[[#_Ref329181937|Table 9]] provides the particulars of each platform used.
1169
1170
<div id="_Ref329181937" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1171
<span style="text-align: center; font-size: 75%;">'''Table 9: '''Computing Plattforms used.</span></div>
1172
1173
{| style="margin: 1em auto 0.1em auto;border-collapse: collapse;" 
1174
|-
1175
|  style="border: 1pt solid black;text-align: center;"|Platform
1176
|  style="border: 1pt solid black;text-align: center;"|Description
1177
|-
1178
|  style="border: 1pt solid black;text-align: center;"|GPU1
1179
|  style="border: 1pt solid black;text-align: center;"|NVIDIA GTX 280
1180
|-
1181
|  style="border: 1pt solid black;text-align: center;"|CPU1
1182
|  style="border: 1pt solid black;text-align: center;"|Intel(R ) Core(TM )2 CPU Q9400 [mailto:@ @] 2.66GHz 2.67GHz
1183
|-
1184
|  style="border: 1pt solid black;text-align: center;"|GPU2
1185
|  style="border: 1pt solid black;text-align: center;"|NVIDIA TESLA C2075
1186
|-
1187
|  style="border: 1pt solid black;text-align: center;"|CPU2
1188
|  style="border: 1pt solid black;text-align: center;"|Intel(R ) Core(TM ) i7-3930K CPU [mailto:@ @] 3.20GHz 3.20GHz
1189
|}
1190
1191
Since hardware evolve quite fast, it is necessary to take into account whether comparison are made with same generation hardware or not. We have named GPU1 and CPU1 to the older platforms, belonging more or less to the same generation, and named CPU2 and GPU2 to the newer platforms, also belonging to the same generation. Therefore, when comparing computational time, it must be taken into account that the newer platforms are about three years younger than the older ones.
1192
1193
<span id='cite-_Ref329182937'></span>[[#_Ref329182937|Table 10]] shows the computational time required for simulating fifty seconds with the coarser mesh and under different solver strategies. The first thing we should point out is that more than eighty percent of the computational time is spent in the linear solver. Therefore, speeding up this part of the code is the key point for acceleration.
1194
1195
<div id="_Ref329182937" class="center" style="width: auto; margin-left: auto; margin-right: auto;">
1196
<span style="text-align: center; font-size: 75%;">'''Table 10: '''Computational time spent for a fifty second simulation of an array sixteen floating cylinders.</span></div>
1197
1198
{| style="width: 100%;margin: 1em auto 0.1em auto;border-collapse: collapse;" 
1199
|-
1200
|  style="border: 1pt solid black;text-align: center;"|
1201
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">PLATFORM</span>
1202
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">PRECONDITIONER</span>
1203
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">Solver time (s)</span>
1204
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|<span style="text-align: center; font-size: 75%;">GPU-CPU </span>
1205
1206
<span style="text-align: center; font-size: 75%;">Speed-up</span>
1207
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">Total time (s)</span>
1208
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">Solver(%)</span>
1209
|-
1210
|  rowspan='6' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">Case 1</span>
1211
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">GPU1</span>
1212
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">SPAI</span>
1213
|  style="border: 1pt solid black;text-align: center;"|564
1214
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|1
1215
|  style="border: 1pt solid black;text-align: center;"|695
1216
|  style="border: 1pt solid black;text-align: center;"|81.2
1217
|-
1218
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">CPU1</span>
1219
|  style="border: 1pt solid black;text-align: center;"|3256
1220
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|5.77
1221
|  style="border: 1pt solid black;text-align: center;"|3325
1222
|  style="border: 1pt solid black;text-align: center;"|97.9
1223
|-
1224
|  style="border: 1pt solid black;text-align: center;"|ILU
1225
|  style="border: 1pt solid black;text-align: center;"|2868
1226
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|5.09
1227
|  style="border: 1pt solid black;text-align: center;"|2938
1228
|  style="border: 1pt solid black;text-align: center;"|97.6
1229
|-
1230
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">GPU2</span>
1231
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">SPAI</span>
1232
|  style="border: 1pt solid black;text-align: center;"|282
1233
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|1
1234
|  style="border: 1pt solid black;text-align: center;"|314
1235
|  style="border: 1pt solid black;text-align: center;"|89.7
1236
|-
1237
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">CPU2</span>
1238
|  style="border: 1pt solid black;text-align: center;"|1217
1239
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|4.32
1240
|  style="border: 1pt solid black;text-align: center;"|1249
1241
|  style="border: 1pt solid black;text-align: center;"|97.5
1242
|-
1243
|  style="border: 1pt solid black;text-align: center;"|ILU
1244
|  style="border: 1pt solid black;text-align: center;"|1123
1245
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|3.98
1246
|  style="border: 1pt solid black;text-align: center;"|1154
1247
|  style="border: 1pt solid black;text-align: center;"|97.3
1248
|-
1249
|  rowspan='6' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">Case 2</span>
1250
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">GPU1</span>
1251
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">SPAI</span>
1252
|  style="border: 1pt solid black;text-align: center;"|2012
1253
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|1
1254
|  style="border: 1pt solid black;text-align: center;"|2284
1255
|  style="border: 1pt solid black;text-align: center;"|88.1
1256
|-
1257
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">CPU1</span>
1258
|  style="border: 1pt solid black;text-align: center;"|15051
1259
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|7.48
1260
|  style="border: 1pt solid black;text-align: center;"|15312
1261
|  style="border: 1pt solid black;text-align: center;"|98.3
1262
|-
1263
|  style="border: 1pt solid black;text-align: center;"|ILU
1264
|  style="border: 1pt solid black;text-align: center;"|13549
1265
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|6.73
1266
|  style="border: 1pt solid black;text-align: center;"|13812
1267
|  style="border: 1pt solid black;text-align: center;"|98.1
1268
|-
1269
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">GPU2</span>
1270
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">SPAI</span>
1271
|  style="border: 1pt solid black;text-align: center;"|1060
1272
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|1
1273
|  style="border: 1pt solid black;text-align: center;"|1178
1274
|  style="border: 1pt solid black;text-align: center;"|90.0
1275
|-
1276
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">CPU2</span>
1277
|  style="border: 1pt solid black;text-align: center;"|6052
1278
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|5.71
1279
|  style="border: 1pt solid black;text-align: center;"|6165
1280
|  style="border: 1pt solid black;text-align: center;"|98.2
1281
|-
1282
|  style="border: 1pt solid black;text-align: center;"|ILU
1283
|  style="border: 1pt solid black;text-align: center;"|5198
1284
|  style="border: 1pt solid black;text-align: center;vertical-align: top;"|4.90
1285
|  style="border: 1pt solid black;text-align: center;"|5311
1286
|  style="border: 1pt solid black;text-align: center;"|97.9
1287
|-
1288
|  rowspan='6' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">Case 3</span>
1289
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">GPU1</span>
1290
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">SPAI</span>
1291
|  style="border: 1pt solid black;text-align: center;"|8519
1292
|  style="border: 1pt solid black;text-align: center;"|1
1293
|  style="border: 1pt solid black;text-align: center;"|9854
1294
|  style="border: 1pt solid black;text-align: center;"|86.4
1295
|-
1296
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">CPU1</span>
1297
|  style="border: 1pt solid black;text-align: center;"|85605
1298
|  style="border: 1pt solid black;text-align: center;"|10.04
1299
|  style="border: 1pt solid black;text-align: center;"|86740
1300
|  style="border: 1pt solid black;text-align: center;"|98.7
1301
|-
1302
|  style="border: 1pt solid black;text-align: center;"|ILU
1303
|  style="border: 1pt solid black;text-align: center;"|75223
1304
|  style="border: 1pt solid black;text-align: center;"|8.83
1305
|  style="border: 1pt solid black;text-align: center;"|76307
1306
|  style="border: 1pt solid black;text-align: center;"|98.6
1307
|-
1308
|  style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">GPU2</span>
1309
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">SPAI</span>
1310
|  style="border: 1pt solid black;text-align: center;"|4743
1311
|  style="border: 1pt solid black;text-align: center;"|1
1312
|  style="border: 1pt solid black;text-align: center;"|5302
1313
|  style="border: 1pt solid black;text-align: center;"|89.4
1314
|-
1315
|  rowspan='2' style="border: 1pt solid black;text-align: center;"|<span style="text-align: center; font-size: 75%;">CPU2</span>
1316
|  style="border: 1pt solid black;text-align: center;"|37479
1317
|  style="border: 1pt solid black;text-align: center;"|7.90
1318
|  style="border: 1pt solid black;text-align: center;"|37941
1319
|  style="border: 1pt solid black;text-align: center;"|98.8
1320
|-
1321
|  style="border: 1pt solid black;text-align: center;"|ILU
1322
|  style="border: 1pt solid black;text-align: center;"|30110
1323
|  style="border: 1pt solid black;text-align: center;"|6.35
1324
|  style="border: 1pt solid black;text-align: center;"|30588
1325
|  style="border: 1pt solid black;text-align: center;"|98.4
1326
|}
1327
1328
The linear solver is the only part of the code also implemented in GPU. Therefore, and since this is the most time consuming part, we will compare computational time spent in solving the linear system.
1329
1330
When comparing GPU1 versus CPU1, the speed up obtained in the linear solver are x5,09, x6.73, and x8.83 for case 1, 2 and 3 respectively. On the other hand, when comparing GPU2 versus CPU2, the speed up obtained in the linear solver are x3.98, x4.90, and x6.35 for case 1, 2 and 3 respectively. It seems like the speed up increases as the size of the case study increases.
1331
1332
When comparing GPU1 versus GPU2, it can be observed that the speed up obtained using the newer generation is in the order of 2. We should also point out that the price of the newer is in the order of ten times more expensive.
1333
1334
Comparing the performance of GPU1 respect to CPU2, we observe that GPU1 performs better, getting speed-ups of x2, x2.58, and x3.53.
1335
1336
The fifty second simulation can be carried out with enough accuracy in some 20 minutes using the platform GPU2. Since the length scale of the model is one meter, those fifty seconds are equivalent to 500 seconds if the radius of each cylinder was one hundred meters. This leads to a ratio between computational time and real time around 2 for offshore engineering problems.
1337
1338
==6. Conclusions==
1339
1340
A FEM solver for wave structure interaction in the time domain has been presented. The wave modelling is based on Stokes perturbation theory, which allows keeping the same computational domain along the simulation. The FEM has been developed so unstructured meshes can be used, no matter the complexity of the structure.
1341
1342
Both, the free surface and outlet boundary conditions are based on implicit schemes. They have been introduced within the system matrix so that no iterations are required within the time step to reach convergence among the Laplace and boundary conditions.
1343
1344
FEM results have been compared to analytical results available for a circular vertical cylinder. The agreement between both solutions shows that the algorithms develop in this work perform well. Response amplitude operators for a freely floating TLP structure obtained by the present FEM and BEM also compare well. Moreover, comparison of response amplitude operators for a semisubmersible platform obtained experimentally shows that the present FEM code is capable of providing practically accurate results.
1345
1346
Deflated solvers have been put to the test for the problem stated in this work. While deflation might be useful for accelerating convergence and reducing CPU time achieving up to x1.4 speed up. However, care must be taken since the acceleration depends on the size of the problem and the dimension of the deflated space. A wrong used of deflated solver might end up in increasing CPU time.
1347
1348
GPUs have been used for solver acceleration. Results indicates that GPUs can perform faster than CPUs, and the speed-ups obtained in this work are in the range of 2-7, depend on the size of the problem, and the generation of GPU/CPU used.
1349
1350
A multi-body simulation has been carried out using sixteen freely floating bodies. It has been shown that the computational time can be reduced so that multi-body ocean engineering problems might be simulated closed to real time. Therefore, this sort of approach could be used for operational purposes in the near future.
1351
1352
==Acknowledgements==
1353
1354
This study was partially supported by the Ministry for Science and Innovation of Spain in the AIDMAR project CTM2008-06565-C03-01, and the Office of Naval Research Global (USA) by the Navy Grant N62909-10-1-7053.
1355
1356
The authors also want to acknowledge Prof. Clauss and Dr. Schmittner, for providing the main characteristics of the GVA4000 model used in the experimental tests.
1357
1358
==References==
1359
1360
<div id="1"></div>
1361
[[#cite-1|[1]]] Cai, X., Langtangen, H. P., Nielsen, B. F. & Tveito, A., A finite element method for fully nonlinear water waves. ''J. Comput. Phys''. 1998; 143: 544–568.
1362
1363
<div id="2"></div>
1364
[[#cite-2|[2]] ] Oñate E. & García, J., A finite element method for fluid-structure interaction with surface waves using a finite calculus formulation, ''Comp. Methods Appl. Mech. and Eng. ''2001; 191: 635-660.
1365
1366
<div id="3"></div>
1367
[[#cite-3|[3]] ] Löhner, R., Yang, C. & Oñate, E., On the simulation of flows with violent free surface motion, ''Comp. Methods Appl. Mech. Eng''. 2006; 195: 5597-5620.
1368
1369
<div id="4"></div>
1370
[[#cite-4|[4]]] Löhner, R., Yang, C. & Oñate, E., On the simulation of flows with violent free surface motion and moving objects using unstructured meshes, ''Comp. Methods Appl. Mech. Engng''. 2007; 53: 1315-1338.
1371
1372
<div id="5"></div>
1373
<span style="text-align: center; font-size: 75%;">[[#cite-5|[5]] ] García, J., Valls A.,</span> <span style="text-align: center; font-size: 75%;">& Oñate, E., ODDLS: A new unstructured mesh finite element method for the analysis of free</span>
1374
1375
surface flow problems,'' Int. J. Numer.  Meth.  Fluids ''2008; 76 (9): 1297-1327.
1376
1377
<div id="6"></div>
1378
[[#cite-6|[6]]] Wu, G.X. & Eatock Taylor, R., Finite element analysis of two dimensional non-linear transient water
1379
1380
waves, ''Appl. Ocean Res''. 1994 ; 16: 363-372.
1381
1382
<div id="7"></div>
1383
[[#cite-7|[7]]] Wu, G.X. & Eatock Taylor, R., Time stepping solution of the two dimensional non-linear wave
1384
1385
radiation problem, ''Ocean Eng.'' 1995; 22: 785-798.
1386
1387
<div id="8"></div>
1388
[[#cite-8|[8]]] Greaves, D.M., Borthwick, A.G.L., Wu, G.X. and Eatock Taylor, R., A moving boundary finite
1389
1390
element method for fully nonlinear wave simulation, ''J. Ship Res''. 1997; 41: 181-194.
1391
1392
<div id="9"></div>
1393
<span style="text-align: center; font-size: 75%;">[[#cite-9|[9]]] Robertson, I. & Sherwin, S., Free-surface flow simulation using hp/spectral elements, ''J. Comp. Phys. ''1999</span>; <span style="text-align: center; font-size: 75%;">155: 26-53.</span>
1394
1395
<div id="10"></div>
1396
[[#cite-10|[10]]] Ma, Q.W., Wu, G.X. and Eatock Taylor, R., Finite element simulation of fully nonlinear interaction between vertical cylinders and steep waves--part 1 methodology and numerical procedure, ''Int. J. Numer.  Meth.  Fluids ''2001; 36: 265-285.
1397
1398
<div id="11"></div>
1399
[[#cite-11|[11]]] Ma, Q.W., Wu, G.X. and Eatock Taylor, R., Finite element simulation of fully nonlinear interaction between vertical cylinders and steep waves--part 2 numerical results and validation, ''Int. J. Numer. Meth.  Fluids'' 2001; 36: 265-285.
1400
1401
<div id="12"></div>
1402
[[#cite-12|[12]]] Westhuis, J.H., The numerical simulation of nonlinear waves in the hydrodynamic model test basin, Ph.D. Thesis 2001, Universiteit Twente, The Netherlands.
1403
1404
<div id="13"></div>
1405
[[#cite-13|[13]]] P.X. Hu, G.X. Wu and Q.W. Ma, Numerical simulation of nonlinear wave radiation by a moving vertical cylinder, ''Ocean Engn'' ''.'' 2002; 29: 1733–1750.
1406
1407
<div id="14"></div>
1408
[[#cite-14|[14]]] M.S. Turnbull, A.G.L. Borthwick and R. Eatock Taylor, Wave-structure intersection using coupled structured-unstructured finite element meshes, ''Applied Ocean Research'' 2003; 25: 63–77.
1409
1410
<div id="15"></div>
1411
[[#cite-15|[15]]] G.X. Wu and Z.Z. Hu, Simulation of nonlinear interactions between waves and floating bodies through a finite element based numerical tank”, ''Proceedings of the Royal Society of London A'' 2004; 460: 2797–2817.
1412
1413
<div id="16"></div>
1414
[[#cite-16|[16]]] C.Z. Wang and B.C. Khoo, Finite element analysis of two-dimensional nonlinear sloshing problems in random excitations, ''Ocean Engineering'' 2005; 32: 107–133.
1415
1416
<div id="17"></div>
1417
[[#cite-17|[17]]] C.Z. Wang and G.X. Wu, Time domain analysis of second order wave diffraction by an array of vertical cylinders, ''Journal of Fluids and Structures'' 2007; 23 (4): 605–631.
1418
1419
<div id="18"></div>
1420
[[#cite-18|[18]]] C.Z. Wang and G.X. Wu, Analysis of second-order resonance in wave interactions with floating bodies through a finite-element method, ''Ocean Engineering'' 2008; 35: 717–726.
1421
1422
<div id="19"></div>
1423
[[#cite-19|[19]]] S. Yan, Q.W. Ma, QALE-FEM for modelling 3D overturning waves, ''Int. J. Numer. Meth. Fluids'' 2009 ;  doi:10.1002/fld.2100.
1424
1425
<div id="20"></div>
1426
[[#cite-20|[20]]] Song, H. Tao, L., and Chakrabarti, S., Modelling of water wave interaction with multiple cylinders of arbitrary shape, ''J. Comp. Phys''. 2010; 229: 1498-1513.
1427
1428
<div id="21"></div>
1429
[[#cite-21|[21]]] Lele, S. K., Compact Finite Difference Schemes with Spectral-like Resolution, J. Comp. Phys. 1992; 103: 16-42.
1430
1431
<div id="22"></div>
1432
[[#cite-22|[22]]] Aubry, R., Mut, F.,  Löhner, R., and Juan R. Cebral, Deflated preconditioned conjugate gradient solvers for the Pressure–Poisson equation, J. Comp. Phys. 2008; 227: 10196-10208.
1433
1434
<div id="23"></div>
1435
[[#cite-23|[23]]] Mut, F., Aubry, R., Houzeaux, G., Cebral, J., and Löhner, R., Deflated preconditioned conjugate gradient solvers: extensions and improvements, 48th Aerospace Sciences Meeting and Exhibit, Orlando, FL, January, 2010.
1436
1437
<div id="24"></div>
1438
[[#cite-24|[24]]] F. Mossaiby, R. Rossi, P. Dadvand, and S. Idelsohn, OpenCL-based implementation of an unstructured edge-based finite element convection-diffusion solver on graphics hardware. Int. J. Numer.  Meth.  Engng.  2011; 89, 13:  1635–1651.
1439
1440
<div id="25"></div>
1441
[[#cite-25|[25]]] Bell, N. and Garland, M., Effcient Sparse Matrix-Vector Multiplication on CUDA, NVIDIA Technical Report NVR-2008-004, Dec. 2008.
1442
1443
<div id="26"></div>
1444
[[#cite-26|[26]]] R. McCamy and R. Fuchs, Wave forces on piles: a diffraction theory, ''Tech. Memo No. 69, U.S. Army Corps of Engrs''. 1954.
1445
1446
<div id="27"></div>
1447
[[#cite-27|[27]]] Eatock Taylor, R. and Jefferys, ER., Variability of Hydrodynamic Load Predictions for a Tension Leg Platform, Ocean Eng. 1986, Vol 13; 5, 449-490.
1448
1449
<div id="28"></div>
1450
[[#cite-28|[28]]] WAMIT User Manual. [http://www.wamit.com/manual.htm http://www.wamit.com/manual.htm].
1451
1452
<div id="29"></div>
1453
[[#cite-29|[29]]] Clauss, G. F. ,  Schmittner, C., and Stutz, K., Time-domain investigation of a semisubmersible in rouge waves, 21st International Conference on Offshore Mechanics and Arctic Engineering June 23-28, 2002, Oslo, Norway. OMAE2002-28450.
1454

Return to Servan Camas Garcia-Espinosa 2013a.

Back to Top

Document information

Published on 01/01/2013

DOI: 10.1016/j.jcp.2013.06.023
Licence: CC BY-NC-SA license

Document Score

5

Times cited: 9
Views 88
Recommendations 1

Share this document