- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 564455 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174559
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
) C+ S N! M9 z! l2 F1 w【数学建模】基于matlab三维海浪模型仿真【含Matlab源码 1159期】
2 F3 n( q, n) u- g% ~5 q) r/ u一、简介
8 u; d* g% J' E7 A基于matlab三维海浪模型仿真:海洋工程领域中的浮式结构物设计,需要精确计算海浪载荷,保证满足稳定性和安全性.该文利用MATLAB对Longuet-Higgins长峰波海浪模型和三维不规则短峰波随机海浪模型进行了仿真研究.结果表明,利用海浪谱来模拟三维随机海浪能够得到比较精确的海浪波面图和波高值,进一步根据流体的势流理论就可以分析计算出该结构物受到的海浪载荷,为校验结构物的结构强度提供了必要的基础。
4 h& e( j. w5 M' S
' I6 f6 O/ h: I/ o! K2 z! @
( B2 ?& N. Y; ?, K二、源代码% `- k7 F0 U$ Q$ r0 A
clear all;
' X& c# l5 C6 D( Z0 X& Uclose all;7 U0 A1 T6 h6 ]
+ B" ^) Z# H; x/ m9 b- N
) M# e7 G5 W, [8 D4 S. h; L
nhFig = 0; % Figure Number;, s' h3 P/ M* R2 D; j# [
SeaRegLx = 40e+3; % Sea region length, unit: m. C4 c5 @ k. m; g( R
SeaRegLy = 40e+3; % Sea region length, unit: m
" v) g0 Y+ ~- k. G; f+ D' c% 根据频域采样定理,在确定采样周期即波束的足迹宽度之后,: s) h0 i" J5 X( `
% 可以利用时域采样的采样点数目(通过空间频谱的宽度即根据时域采样定理计算出采样点数),实现频域采样.
1 s/ Y) ]' Q4 m% 对于海洋波谱而言,波谱宽度是非常宽的,因此其波谱宽度一般是指包括了大部分能量(或者说主要的能量部分)的不完全谱宽度
" O) N) n& W, ~2 E6 b' a% 所以这里事先根据波谱函数计算主要能量部分对应的谱宽度+ b% X2 l- A; N y
xSampleStep = 50; % unit: m2 }6 a& s9 `4 A5 n. x ~ r
ySampleStep = 50;
0 b( q' b* g) ] E [7 F1 G0 ^- mxNs = round( SeaRegLx / xSampleStep );
9 n8 K3 R2 K# r1 j3 e1 ]7 ayNs = round( SeaRegLy / ySampleStep );7 e6 `8 d% r6 ^; O! M
) w/ X7 U) {& C$ G4 e. `3 J, x
x = linspace( -SeaRegLx / 2, SeaRegLx / 2, xNs );
+ L+ A" m& C! |- N# \, S& qy = linspace( -SeaRegLy/ 2, SeaRegLy / 2, yNs );
3 S/ C5 {2 T7 p1 z/ j2 c( \8 V/ q; D! q+ M9 n
" p6 O4 z8 y: |& r1 `4 I
% 海浪谱仿真) l Z. P$ ~% Y2 m
g = 9.8; % gravity acceleration
# p r% D1 L y; e6 D$ o( H% swell wave spectrum parameter, `2 a! y% B- ^' F
SwellWaveLength = 1000; % 涌浪波长
, i3 ~% o9 Q% h# r2 \, v0 VKswellWavePeak = 2 * pi / SwellWaveLength;8 V4 k! B. o' {/ C! Q
SwellAngled=0;
1 Y/ k$ N f; MSwellAngle = SwellAngled/ 180 * pi; % 涌浪与观测向夹角
1 } v& N) D! R" n/ I% AKxswellWavePeak = KswellWavePeak * cos( SwellAngle );
$ Q9 H+ m4 E3 I3 [# e! x2 w/ qKyswellWavePeak = KswellWavePeak * sin( SwellAngle );
" C# p$ j+ t1 C7 Y6 Y' j1 BSigmaKx = 2.5e-3; % 涌浪谱宽度4 ^# v, S( S `( e6 v! U
SigmaKy = 2.5e-3;
3 ~4 z# Y8 U' z) `- lSigmaHSwell = 2; %涌浪波高7 y+ @+ ?& _' m; q: a" Z
% wind wave spectrum parameter' u9 w9 ^5 Y8 B& P; Z
WindAngle = 45 / 180 * pi; % 风向与观测向夹角
6 k( R! Z4 |" F. l$ UU10 = 12; % 10米高处海面风速 % 5m/s, 10m/s, 15m/s 的风浪谱宽度分别为 1.5, 0.4, 0.15.对应的最大空间采样间隔为2m, 10m, 20m
5 j6 _& y/ H- r! b# _4 g; g7 SKwindPeak = g / ( 1.2 * U10 )^2; W7 k: E F/ m' P3 m) q
% sea wave spectrum parameter; t/ r% i1 J% L B
NxSeaWave = xNs; % 频域采样点数,方便傅立叶变换
0 z j6 ~% @ q% |% d; U# MNySeaWave = yNs;
# e+ O9 X$ W' w" M& w& y; DKxSeaWave = 2 * pi / SeaRegLx * ( -xNs / 2 : 1 : xNs / 2 - 1 );& B7 l+ A7 x" _6 w6 y$ K ^
KySeaWave = 2 * pi / SeaRegLy * ( -yNs / 2 : 1 : yNs / 2 - 1 );1 G- Y+ P9 I" K" w% Q
KxSeaWaveTicks = KxSeaWave;0 Q( m+ G& I: q
KySeaWaveTicks = KySeaWave;; s7 L2 N+ S$ u$ N
KxSeaWave = ( KxSeaWave == 0 ) * ( max( KxSeaWave ) * 1e-16 ) + KxSeaWave; % avoid divided by 0
/ L5 q( f2 B* `- u4 K6 lKySeaWave = ( KySeaWave == 0 ) * ( max( KySeaWave ) * 1e-16 ) + KySeaWave; % avoid divided by 0
; A5 e; Q! @! E. M" }0 H
: {+ Z4 U- F- s2 G
9 M: c; Z; T {: _' T! N4 R2 ?$ e% swell wave spectrum
0 z p3 o' w6 w7 L) PSpectrumSwell = zeros( NySeaWave, NxSeaWave );# W+ d) G1 R: d3 E% y
Temp1 = ones( NySeaWave, 1 ) * ( KxSeaWave - KxswellWavePeak ) / SigmaKx;" f* s1 g8 v3 O( C7 {4 U7 N
Temp2 = ( KySeaWave - KyswellWavePeak )' / SigmaKy * ones( 1, NxSeaWave );
& W( c5 c( C5 dSpectrumSwell = SigmaHSwell^2 / 2 / pi / SigmaKx / SigmaKy * exp( -0.5 * ( Temp1.^2 + Temp2.^2 ) );
9 W; f' V9 N, q: S* jclear Temp1;+ N, q/ @# L' D' q. @
clear Temp2;
: u( f7 S6 s" I7 _2 Qfigure;9 a4 ?: ^6 B% ]3 W
colormap(gray(256));
! {; j3 x2 Z* }9 ?" s \image( KxSeaWave, KySeaWave, 256 - 255 / ( max( max( abs( SpectrumSwell ) ) ) - min( min ( abs( SpectrumSwell ) ) ) ) * ( abs( SpectrumSwell ) - min( min ( abs( SpectrumSwell ) ) ) ) );+ V7 F( P$ C5 f! B" Y
axis('xy');
( ?5 q6 _! f6 Txlabel( 'kx:X方向波数');
! O2 ]- V) C: }4 M" @ Pylabel( 'ky:Y方向波数');
" L$ h) v2 u3 Dtitle( '涌浪谱');- c* Y+ D' L/ P4 X: q6 I
# q, B- T7 J p5 a) C, t* n4 J8 C; w& a
KxSeaWaveMatrix = ones( NySeaWave, 1 ) * KxSeaWave;
( H0 d$ B9 J' J: _1 xKySeaWaveMatrix = KySeaWave' * ones( 1, NxSeaWave );
0 y; G6 D8 z5 t) QKSeaWaveTemp1 = ( sqrt( KxSeaWaveMatrix.^2 + KySeaWaveMatrix.^2 ) );
7 t. ~0 B Q/ }% hFwk1 = exp( - 1.22 * ( sqrt( KSeaWaveTemp1 ./ KwindPeak ) -1 ).^2 ); z& E C& i* T t9 a/ C1 e: m
HKKpx1 = 1.24 * ( ( KSeaWaveTemp1 / KwindPeak < 0.31 ) & ( KSeaWaveTemp1 / KwindPeak >= 0 ) );
, t3 G& [$ l0 Y yHKKpx2 = 2.61 * ( ( KSeaWaveTemp1 / KwindPeak ).^0.65 ) .* ( ( KSeaWaveTemp1 / KwindPeak < 0.9 ) & ( KSeaWaveTemp1 / KwindPeak >= 0.31 ) );2 b" O2 K! j. m3 G
HKKpx3 = 2.28 * ( ( KSeaWaveTemp1 / KwindPeak ).^( -0.65 ) ) .* ( KSeaWaveTemp1 / KwindPeak >= 0.9 );
9 `4 x- ?5 v; x" j) tHKKp1 = HKKpx1 + HKKpx2 + HKKpx3;! _; T+ ~# u# R R! V! T
Temp1x = 1.62 * 1e-3 * U10 / ( g^0.5 ) ./ ( KSeaWaveTemp1 ).^3.5;; T! [; y9 E7 {" G) F. c4 X% ~; E
Temp2x = exp( -( KwindPeak ./ KSeaWaveTemp1 ).^2 ) .* ( 1.7 .^ Fwk1 );
; W$ _; ]6 h' |9 k' mTemp3x = ( HKKp1 .* ( sech( ( HKKp1 .* ( atan( ( KySeaWaveMatrix ./ KxSeaWaveMatrix ) ) - WindAngle ) ) ) ).^2 );. B1 b; B3 b: z4 C) I
% SpectrumWind1 = ( Temp1x .* Temp2x .* Temp3x )';; D, H! ?0 {+ r5 n
fid=fopen('sea_top_wl1000_wh50m.dat','w')7 ?+ p; }( X7 k5 T6 X$ u# G
fprintf(fid,'%10.5f\n',real(wh));
% _9 X; s4 h6 p+ X2 Z! N& ystatus=fclose(fid);; q6 U8 ?% q5 a0 A
2 }! E4 v9 P' E
3 L6 f Q' ?' Q9 gfid=fopen('sea_top_wl1000_wh50m.dat','r');
; ?# _$ t2 F0 O. }( `/ Wsea_dem=fscanf(fid,'%g',[800,800]);& V2 y" A3 ~. r- ^1 m2 w
fclose(fid);7 L5 ?: B2 [( Z8 s9 Q# P- d
%image( x, y, 256 - 255 / ( max( max( real( sea_dem ) ) ) - min( min ( real( sea_dem ) ) ) ) * ( real( sea_dem ) - min( min ( real( sea_dem ) ) ) ) );
, t* o$ T- E, L: g% ?- k# E( {/ E. T1 b2 p
mesh(sea_dem)8 ?, |+ S& i+ V9 s+ m* `7 R3 N
colorbar
. @+ J9 Q+ K7 Y! O' v4 P/ {, I% view(0,90)
5 z% M/ s6 z0 T% h' @% D%colormap(gray)9 b, } b2 B- O, t' i
% This function computes the non-coherent integration improvment% h: ~8 A4 Z: t* `. b
% factor using the empirical formula defind in Eq. (2.48)3 ?7 t( ^; J0 ~9 j8 n/ z2 M
fact1 = 1.0 + log10( 1.0 / pfa) / 46.6;4 ^4 d5 |' `) a g) P
fact2 = 6.79 * (1.0 + 0.235 * pd);
3 n w6 G Y' o) K! rfact3 = 1.0 - 0.14 * log10(np) + 0.0183 * (log10(np))^2;" d1 E1 m- ~. j5 i
impr_of_np = fact1 * fact2 * fact3 * log10(np);* a8 x Q P2 P5 o* c$ R
return
, z2 U6 M Q" m* G M5 a$ s( h% S( a7 C' U6 w8 w2 ]
8 B( ]* w- l# T# \9 w; M- T% SpectrumWind = SpectrumWind1';
5 c) }, j7 E+ _; ]$ K9 c* XSpectrumWind = Temp1x .* Temp2x .* Temp3x;9 a7 [$ f0 t+ u3 ?
clear KSeaWaveTemp1 Fwk1 HKKpx1 HKKpx2 HKKpx3 HKKp1 Temp1x Temp2x Temp3x;: O- H2 U; ~8 o: I
! [! n: y0 V) n6 f3 E. T7 m
6 t# R* V+ C! A# h* s$ G1
# |* E7 u8 @7 v; ?) ]2( a% u7 Y, b6 F. B, a/ W# B
3* s5 g- w! ?6 ]7 N" L2 E
4( Z. a- Z0 r6 D$ G
5
' c6 y' \* v/ M* F' U. P3 ?6' P+ w V) H0 G$ C/ S! F. P3 m
7, s: F5 q2 o) }8 [7 l
8
! o7 k1 v t" q, i2 G" Z7 ~9
( C: |# r% k- u) ~4 I5 ^9 }0 F3 y106 Z( ]7 I F- h. c7 I7 z/ s% V
11
4 }* N8 I2 z- v% m ~12+ y H& s1 e) L* h
13
: V: ]+ s6 `7 G8 j& n% {8 V! e2 q14
* y( s" v9 R v15
9 x3 b: s8 [4 X3 J: H# F16, z9 m: f; C/ V1 [- R
17
% ?6 m! _; `" B2 o182 ?1 n0 @$ H$ T, o$ U
19
; b# |% S- O! N8 ~20
9 A; J5 p' v$ ~6 A7 l& }9 q21! ]; V& q/ s& h! [. r) x
22
/ \6 Q' N7 c' P/ Z* C, ~7 u, g23
2 j2 Y+ H% s6 b. h, F24+ ?; W3 j0 L( ]7 M [7 }$ K% ^
25
; d8 V9 I) d( p26
0 r: ^" E2 D" N27
3 i! ^( R$ t3 F# j& b3 F m6 e28! S1 ~& ~$ r# c6 p. H
29
; `8 u) S8 }, X" w, z1 @0 E' D309 l4 ~0 [7 H, ]; |4 @( }9 f" l
31
) k) Q6 a* {9 g3 J32
; B( c9 C" W7 T' N/ c334 b3 _* G7 A5 N. H, |; C" B' q n5 m
346 g; @& O$ l; ]) T) n& U
35
+ b2 W- F3 p! E& R& H36
! K% X9 X; b, R$ O& I) V- B370 N3 {8 ]/ r- T. ?, C* G
38
$ D8 m) K2 \% f& g39
C$ f8 A. f/ y2 c( Y& \5 e40
/ [( b* `: l0 y/ E41: Q9 v2 G, w& T5 X1 ~8 m
42" L3 S- ?5 k7 ?) U
43/ s5 s0 K6 I/ \" a! \! O" R
44
) s0 I& u, ? P& t45
7 }: ?( G8 \+ h0 T46! n3 D, h: R7 e! M
47% K: S& Z* A2 x' J U0 J
488 _1 L, ]5 }) |3 d9 V$ n, f
49
3 ~( N" F1 X s+ b: ]50
. d, @7 u- e' R/ V( e- U' W) t# w" M51
8 H1 `" v0 `" c' P52
# X# k" c- b/ w) M3 m) m- ]536 x( i' l$ @ d! V$ y$ n: E b* u
54: o$ B. s: c1 w* ~* {
55
6 s" ~3 P& y0 ?56
6 `6 }5 J0 P1 |% b57( I8 c$ N% ^# B& [" c6 [! o
58
! Z n5 c$ `9 d/ x- ^59
; ?; V8 H) e+ A1 e! J60. w7 } ^# b2 Z3 k' q! `
618 u% T9 J! ~6 P6 d* p- O% z! y3 W
62
% i/ s6 v; s% f+ Z! P ]63! Z+ h5 s$ J1 ]# F& r: C9 W, j; P6 `
64" H1 Y, J- T4 E8 R) {( z
65
' ~" v! i, r F0 X. L" V1 n66
1 o$ j% j8 N6 K. r9 ?2 v5 g2 E67& S0 w4 o! t7 E( [! ^
68; h9 ^4 U/ B6 J( o; M
69/ e. R2 i3 Y5 b7 @' P
70' F; W! Z9 C* U9 R2 h6 G, l
71/ ?% V. q1 k G
72, p6 }/ E9 |; [3 o# M7 t" j
73$ A5 `7 a8 h7 j6 [$ v' b3 i' g
74
5 ]" \, |/ G& w! H8 ]75
8 {' w2 P9 D+ h9 V$ Y! ~760 U6 V6 L8 f9 H d6 u0 N
77
: M* s/ x& }4 t+ E& n0 V# Y0 ]78# G" A7 l- K; {
79
r: h1 l8 L, F* r3 R# G80
3 M( B( y& S/ n7 o- u1 C! b81$ W. R- p4 y- g7 D6 c* d
82
6 E) u1 n' _% H. B83! h. j& z9 K% |' T( b$ X
84
: ` L% J( U4 b2 f$ ?85
5 v! b* |$ R6 L7 N86
1 Q% O* t( A) B. S; \87! U% Z2 Y* j; n5 q3 U
88
7 C; Y/ S: E7 N# f% |+ [3 D/ n6 G89
% Z) Q# }5 R: L( D90+ _* y ?% V+ Q6 S) S
914 C! v0 }, e" @- R
92
* e3 y) |* \5 P93
: f% b# H L p) N- O4 O4 C+ t; }94
! q/ S n8 i# T7 T. d. y: ~1 d95: |+ ^' \, i, `( d" x
96* \8 @" o+ `' l$ _+ x9 u8 R
三、运行结果- j: V1 G a7 e9 J+ M
+ x: u% }, x9 d d* P, ~2 W. j. G" y
6 Z# k/ ^+ b" S, R2 R, o; B5 d6 R6 t7 ]# L$ Z
2 W! Q6 y- Q+ `& N3 c8 c" J# O% Q% k
) ]& P2 }, j0 w! {4 l$ K
; t6 f* g6 J; J! U' a8 ^6 Z Y& X0 k& X7 O! O8 W
# r: ~; o( B% h o( K
2 e! d. M; n7 c. o
3 T0 K: {) [* n) u四、备注
3 Q7 x5 E2 ?+ `+ q版本:2014a; e& K- y& w) ?7 a% o* f
————————————————
7 ] v- C% q1 y$ J& T" L版权声明:本文为CSDN博主「紫极神光」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
; [' r8 Z, d; f9 s: A! A& D原文链接:https://blog.csdn.net/TIQCmatlab/article/details/119220599
' Y# s6 n$ Y+ x, ~
' ~8 P# j0 O5 V
0 }, K# Z6 B" Y& ?3 C" h" f5 L |
zan
|