Этот пример симулирует явление волны цунами при помощи Symbolic Math Toolbox™, чтобы решить дифференциальные уравнения.
Эта симуляция является упрощенной визуализацией явления и основана на статье путем Бодания и Raichlen [1].
Уединенная волна (решение для солитона Уравнения Кортевега де Вриза) перемещается на постоянной скорости справа налево вдоль канала постоянной глубины. Это соответствует цунами, перемещающемуся по глубокому морю. В левом конце канала существует наклон, симулирующий континентальный шельф. После достижения наклона уединенная волна начинает увеличивать свою высоту. Когда вода становится очень мелкой, большая часть волны отражается назад в канал. Однако узкий, но высокий пик воды возникает в конце наклона и возобновляет сниженную скорость в первоначальном направлении инцидентной волны. Это - цунами, которое наконец обрушивается на берег, вызывая катастрофическое разрушение вдоль береговой линии. Скорость волны, приближающейся к берегу, сравнительно мала. Волна в конечном счете начинает повреждаться.
Используя линейную водную теорию без рассеяния, высоту из волны свободной поверхности выше уровня воды без помех в одномерном канале различной глубины решение следующего дифференциального уравнения с частными производными. (См. [2].)
В этой формуле индексы обозначают частные производные, и гравитационное ускорение.
Рассмотрите волну, пересекающую линейный наклон из области с постоянной глубиной в область с постоянной глубиной . Преобразование Фурье относительно поворачивает дифференциальное уравнение с частными производными водной волны к следующему обыкновенному дифференциальному уравнению для режима Фурье .
Для областей с постоянной глубиной , режимы Фурье перемещаются распространение волн в противоположных направлениях с постоянной скоростью .
Решение поскольку глубоководная область является суперпозицией двух волн:
волна, перемещающаяся налево с постоянной скоростью
волна, перемещающаяся направо с амплитудой, данной зависимым частоты отражательный коэффициент
Этот выбор удовлетворяет уравнению волны в глубоководной области для любого .
Решение для мелководья область является переданной волной, перемещающейся налево с постоянной скоростью . Этот выбор удовлетворяет уравнению волны в мелководной области для любого коэффициента передачи .
Для области перехода (наклон), использовать .
Задайте параметры модели цунами можно следующим образом. Игнорируйте зависимость от частоты в следующих обозначениях: , , .
syms L H depthratio g positive syms x t w T R U(x) L1 = depthratio*L; L2 = L; h1 = depthratio*H; h2 = H; h(x) = x*H/L; c1 = sqrt(g*h1); c2 = sqrt(g*h2); u(x,t) = U(x)*exp(1i*w*t); u1(x,t) = T*exp(1i*w*(t + x/c1)); u2(x,t) = exp(1i*w*(t + x/c2)) + R*exp(1i*w*(t - x/c2));
В области перехода по линейному наклону используйте dsolve
решать ОДУ для преобразования Фурье из .
wavePDE(x,t) = diff(u,t,t) - g*diff(h(x)*diff(u,x),x); slopeODE(x) = wavePDE(x,0); U(x) = dsolve(slopeODE);
Решение сложное выражение, включающее Функции Бесселя. Это содержит две произвольных "константы", которые зависят от .
Const = setdiff(symvar(U), sym([depthratio,g,H,L,x,w]))
Const =
Для любого режима Фурье полное решение должно быть непрерывно дифференцируемой функцией . Следовательно, значения функции и производные должны соответствовать в точках шва и . Это обеспечивает четыре линейных уравнения для , , и эти две константы в .
du1(x) = diff(u1(x,0),x);
du2(x) = diff(u2(x,0),x);
dU(x) = diff(U(x),x);
eqs = [ U(L1) == u1(L1,0), U(L2) == u2(L2,0),...
dU(L1) == du1(L1), dU(L2) == du2(L2)];
unknowns = [Const(1),Const(2),R,T];
Решите эти уравнения.
[Cvalue1, Cvalue2, R, T] = solve(eqs, unknowns);
Замените результатами назад в , , и .
U(x) = subs(U(x), {Const(1),Const(2)}, {Cvalue1,Cvalue2});
Вы не можете непосредственно оценить решение для потому что и числитель и знаменатель соответствующих выражений исчезают. Вместо этого найдите низкочастотные пределы этих выражений.
simplify(limit(U(x), w, 0))
ans =
simplify(limit(R, w, 0))
ans =
simplify(limit(T, w, 0))
ans =
Эти пределы удивительно просты. Они только зависят от отношения значений глубины, задающих наклон.
Для следующих расчетов используйте эти численные значения для символьных параметров.
Гравитационное ускорение:
Глубина канала:
Отношение глубины между отмелью и глубокими областями:
Длина наклонной области:
g = 9.81; L = 2; H = 1; depthratio = 0.04; h1 = depthratio*H; h2 = H; L1 = depthratio*L; L2 = L; c1 = sqrt(g*h1); c2 = sqrt(g*h2);
Задайте входящий солитон амплитуды перемещение налево с постоянной скоростью в глубоководной области.
A = 0.3; soliton = @(x,t) A.*sech(sqrt(3/4*g*A/H)*(x/c2+t)).^2;
Выбрать точки выборки для . Масштаб времени выбран в качестве кратного (временной) ширине входящего солитона. Сохраните соответствующие дискретизированные частоты преобразования Фурье в .
Nt = 64; TimeScale = 40*sqrt(4/3*H/A/g); W = [0, 1:Nt/2 - 1, -(Nt/2 - 1):-1]'*2*pi/TimeScale;
Выбрать точки выборки в направление для каждой области. Создайте точки выборки для мелководной области, для глубоководной области, и для наклонной области.
Nx = 100; x_min = L1 - 4; x_max = L2 + 12; X12 = linspace(L1, L2, Nx); X1 = linspace(x_min, L1, Nx); X2 = linspace(L2, x_max, Nx);
Вычислите преобразование Фурье входящего солитона на сетке времени равноотстоящие точки выборки.
S = fft(soliton(-0.8*TimeScale*c2, linspace(0,TimeScale,2*(Nt/2)-1)))'; S = repmat(S,1,Nx);
Создайте перемещающееся решение волны в глубоководной области на основе данных Фурье в .
soliton = real(ifft(S .* exp(1i*W*X2/c2)));
Преобразуйте режимы Фурье отраженной волны в глубоководной области к численным значениям по сетке в пробел. Умножьте эти значения с коэффициентами Фурье в и используйте функциональный ifft
вычислить отраженную волну в пробел. Обратите внимание на то, что первая строка числовых данных состоит из значений NaN потому что соответствующая численная оценка символьных данных для не возможно. Задайте значения в первой строке как низкочастотные пределы.
R = double(subs(subs(vpa(subs(R)), w, W), x ,X2)); R(1,:) = double((1-sqrt(depthratio)) / (1+sqrt(depthratio))); reflectedWave = real(ifft(S .* R .* exp(-1i*W*X2/c2)));
Используйте тот же подход для переданной волны в мелководной области.
T = double(subs(subs(vpa(subs(T)),w,W),x,X1)); T(1,:) = double(2/(1+sqrt(depthratio))); transmittedWave = real(ifft(S .* T .* exp(1i*W*X1/c1)));
Кроме того, используйте этот подход для наклонной области.
U12 = double(subs(subs(vpa(subs(U(x))),w,W),x,X12)); U12(1,:) = double(2/(1+sqrt(depthratio))); U12 = real(ifft(S .* U12));
Для более сглаженной анимации сгенерируйте дополнительные точки выборки с помощью тригонометрической интерполяции вдоль столбцов данных о графике.
soliton = interpft(soliton, 10*Nt); reflectedWave = interpft(reflectedWave, 10*Nt); U12 = interpft(U12, 10*Nt); transmittedWave = interpft(transmittedWave, 10*Nt);
Создайте анимированный график решения что показы в отдельном окне рисунка.
figure('Visible', 'on'); plot([x_min, L1, L2, x_max], [-h1, -h1, -h2, -h2], 'Color', 'black') axis([x_min, x_max, -H-0.1, 0.6]) hold on line1 = plot(X1,transmittedWave(1,:), 'Color', 'blue'); line12 = plot(X12,U12(1,:), 'Color', 'blue'); line2 = plot(X2,soliton(1,:) + reflectedWave(1,:), 'Color', 'blue'); for t = 2 : size(soliton, 1)*0.35 line1.YData = transmittedWave(t,:); line12.YData = U12(t,:); line2.YData = soliton(t,:) + reflectedWave(t,:); pause(0.1) end
В реальной жизни цунами имеют длину волны сотен километров, часто перемещающихся на скоростях больше чем 500 км/час. (Обратите внимание на то, что средняя глубина океана составляет приблизительно 4 км, соответствуя скорости .) По глубокому морю амплитуда скорее мала, часто приблизительно 0,5 м или меньше. При распространении на полку, однако, цунами увеличивают свою высоту существенно: амплитуды до 30 м и о большем сообщили.
Одно интересное явление - то, что несмотря на то, что цунами обычно приближаются к береговой линии как к расширению фронта волны для сотен перпендикуляра километров к направлению, в котором они перемещаются, они не наносят универсальный ущерб вдоль побережья. В некоторых точках они вызывают бедствия, тогда как только умеренные явления волны наблюдаются в других местах. Это вызывается различными наклонами от морского дна до континентального шельфа. На самом деле очень крутые склоны заставляют большую часть цунами быть отраженной назад в область глубоководных, тогда как маленькие наклоны отражают меньше волны, передавая узкую, но высокую волну, несущую много энергии.
Запустите симуляцию для различных значений , которые соответствуют различным наклонам. Чем более крутой наклон, тем ниже и менее мощный волна, которая передается.
Обратите внимание на то, что эта модель игнорирует эффекты трения и дисперсия. На полке симуляция теряет свой физический смысл. Здесь, эффекты трения важны, вызывая повреждение волн.
[1] Дерек Г. Горинг и Ф. Рэйчлен, Цунами - Распространение Длинных волн на Полку, Журнал Водного пути, Порта, Прибрежной и Океанской Разработки 118 (1), 1992, стр 41 - 63.
[2] Х. Лэмб, гидродинамика, Дувр, 1932.