ME2623 Engineering Mathematics and Programming

Hello, if you have any need, please feel free to consult us, this is my wechat: wx91due

Module Code: ME2623

Module Title: Engineering Mathematics and Programming

Assessment Title: Solving the 2D Wave Equation Using the Finite Difference Method

Weighting: 40%

Main objectives of the assessment:

To develop and document a MATLAB program that solves the 2D wave equation using the finite difference method, demonstrating an understanding of numerical methods, code implementation, and validation techniques.

Brief Description of the assessment:

The student is required to develop a MATLAB program to solve the 2D wave equation using the finite difference method. Additionally, the student must provide a user guide explaining the functionality of the code, validate its results, and propose potential enhancements for future applications.

Learning outcomes for the assessment:

1.    Understanding of analytical methods that are

useful for Mechanical and Aerospace Engineering

2.    Understanding how to employ programming to solve basic engineering computational problems.

3.    Applying best-practice programming techniques to solve Mathematical models of Engineering

problems.

4.    Understanding the usefulness of programming techniques in the process of solving Engineering problems.

5.    Presenting computational results in a clear and concise manner including validation and

verification.

Assessment and marking criteria

This assignment will be assessed based on several criteria, each contributing to the final grade as

indicated by the percentage in brackets:

● Explaining the interface (20%)

 Providing a quickstart example (20%)

 Code annotation (20%)

 Verification and validation (20%)

 Suggesting future extensions (10%)

 Including an appendix with the code (10%)

Your submission will be assessed based on:

•     Accuracy   and    stability of the    numerical implementation.

•     Clarity    and    comprehensiveness    of your documentation.

•     Creativity     and     feasibility     of     proposed extensions.

Assessment method by which a student can demonstrate learning outcomes:

Completion of the assignment defined above, which must be submitted via WISEflow for marking.

Format for the assessment/coursework (Guidelines on the expected format and length of submission):

The university takes academic misconduct very seriously. Further information about this subject can be found here:

• Senate regulation 6: https://www.brunel.ac.uk/about/documents/pdf/Senate-Regulation-6-2020-07-01.pdf

• Library: https://www.brunel.ac.uk/life/library/SubjectSupport/Plagiarism

The university’s policy on using artificial intelligence in your studies can be found here:

https://students.brunel.ac.uk/study/using-artificial-intelligence-in-your-studies

Distribution date to students: 6th December 2024

Submission Deadline: 6th January 2025

Indicative Reading List:

Further information:

Assignments must be submitted to WISEflow in PDF format (unless stated otherwise), using Arial size

11 font and limited to no more than three pages. Students are strongly advised to submit their assignments well ahead of the deadline.

Late submissions are subject to penalties.

Assignment Brief

Solve the following free-vibration 2D hyperbolic equation using the finite difference method:


Initial condition:


Boundary condition:

u(0,y, t)=u(1,y, t)=u(x,0, t)=u(x,1, t)=0,    t>0

Stability condition:

It is suggested that Δx=ΔY. Ensure your numerical scheme satisfies the explicit stability condition:

Note: the stability condition of the explicit time scheme of the 2D wave equation

Using afunction with the following interface,

function u = solve_wave_eq(uinitial,c, Lx, Ly, Mx, My,maxIter,showplot)

Where:

Inputs

u_initial

Initial displacement field (size MX XMYrepresenting u(x,y,0) .

c

Wave speed (c= 1.5).

Lx,Ly

Length of the domain in the x andy directions

Mx,My

Number of cells in the  andy directions (e.g., MX=20, MY=20).

dt

Time step size (must satisfy the stability condition)

maxIter

Maximum number of time steps to solve

showplot

Boolean flag to enable/disable plotting of the wave

Output

u

Final displacement field after solving the 2D wave equation for maxIter steps

Task

1. Explain the Interface

1.1  Describe what an interface is in computing and explain the scope of the function in terms of its inputs and outputs.

1.2  Detail the shapes of uinitial and the returned u.

2. Quickstart Example

2.1 Write a quickstart guide explaining how to use the function. Include at least one example test case

(e.g.,   u initial=s in(2mx).s in(4my),     L X=LY=1,    MX=MY= 20)

2.2  Include plots showing the wave propagation at various time steps, and explain the physical significance of these results.

2.3  If the code doesn’t work as expected, explain what behaviour you would anticipate.

3. Code Annotation

3.1 Choose two critical snippets of code and describe how they work:

3.1.1 Calculating u at the next time step using the finite difference method. 3.1.2 Implementing the boundary conditions.

4. Verification and Validation

4.1  Discuss how you verified and validated the code.

Verification: Ensuring the code is solving the equations correctly (e.g., stability tests).

Validation: Confirming the code produces realistic and accurate results (e.g., comparing to analytical solutions or expected behaviours).

4.2 Suggest  at  least  one  validation  case   (e.g., u(x,y,0)=s in(2mx).s in(4my)) and  comparing  with analytical solutions for specific times).

5. Future Extensions

5.1 Suggest  possible  extensions  to  the  code   (e.g.,  adding  absorbing   boundary  conditions,   modelling nonlinear waves, or introducing energy loss). Briefly explain how these could be implemented.

6. Appendix

6.1  Include the full MATLAB code as an appendix. Ensure the code is thoroughly commented to describe each step.

Example Test Case:

Run the following scenario to validate your code:

● u initial(x, y)=s in(2nx).s in(4ny)

● L X=LY=1

● MX=MY=20

●    dt= 0.002 (ensuring stability condition is met)

● max lter= 100

Visualize the results in several time steps (e.g., t=0,0.02,0.04) and describe the behaviour of the wave.

Code Requirements:

i.        Use the explicit finite difference method to solve the wave equation.

ii.        Implement fixed boundary conditions as specified.

iii.        Include input validation to check:

•     dt satisfies the stability condition.

• u_initial matches the size Mx × My .

•     All inputs are numeric and have appropriate dimensions.

Suggestions:

i.        Format your submission to include the required sections: Interface explanation, quickstart example, annotated code, verification/validation, and future extensions.

ii.        Use plots and error analysis from the code to support your explanations.

iii.        Ensure the MATLAB code is included as an appendix with additional comments if necessary.

Notes:

i.        Refer to lecture slides, textbooks, or MATLAB documentation if needed.

ii.        Unit tests are encouraged to ensure correct implementation.

MATLAB Code

clc; clear all; close all;

%2D WAVE EQUATION utt = c^2(uxx+uyy)

%with initial condition  u(x,y,0) = sin(p*pi*x)*sin(q*pi*y), 0 0 % and boundary conditions u(0,y,t) = u(1,y,t)= u(x,0,t)= u(x,1,t) = 0 t>0 c = 1.5;

dx = 0.01; dy = dx;

sigma = 1/sqrt(2); gamma = 1/sqrt(2); %Courant-Friedrich Stability Condition dt = sigma*(dx/c);

t = 0:dt:1; x = 0:dx:1; y = 0:dy:1;

u = zeros(length(x),length(y),length(t)); p = 2; q = 4;

u(:,:,1) = transpose(sin(p.*pi.*x))*sin(q.*pi.*y); %u(x,y,0) = sin(p*pi*x)*sin(q*pi*y) %u(x,y,dt)

for i=2:length(x)-1

for j=2:length(y)-1

u(i,j,2)= (sigma^2)*(u(i+1,j,1)-2*u(i,j,1)+u(i-1,j,1))...

+(gamma^2)*(u(i,j+1,1)-2*u(i,j,1)+u(i,j-1,1))+2*u(i,j,1) - u(i,j,1);

end end

for n=2:length(t)-1

for i=2:length(x)-1

for j=2:length(y)-1

u(i,j,n+1)= (sigma^2)*(u(i+1,j,n)-2*u(i,j,n)+u(i-1,j,n))...

+(gamma^2)*(u(i,j+1,n)-2*u(i,j,n)+u(i,j-1,n)) + 2*u(i,j,n) - u(i,j,n-1);

end end

end

%Analytic solution

SOL = zeros(length(x),length(y),length(t)); S = transpose(sin(p.*pi.*x))*sin(q.*pi.*y); for i=1:length(t)

SOL(:,:,i) = S*cos(c.*pi.*(sqrt(p^2+q^2).*t(i)));

end

%Absolute error E = abs(SOL-u);

[X,Y] = meshgrid(x,y);

max_e = max(max(max(E))); for j=1:length(t)

subplot(2,1,1) colormap(cool);

p1 = surf(X,Y,u(:,:,j));

title(sprintf('2D wave equation at t = %1.2f, con sigma = %1.2fy gamma = %1.2f',t(j),sigma, gamma),'Fontsize',11); xlabel('x','Fontsize',11); ylabel('y','Fontsize',11);

zlabel(sprintf('u(x,y,t = %1.2f)',t(j)),'Fontsize',11); axis ([0 1 0 1 -1 1]);

subplot(2,1,2)

p2 = surf(X,Y,E(:,:,j));

title(sprintf('Absolute error at t = %1.2f',t(j)),'Fontsize',11); xlabel('x','Fontsize',11); ylabel('y','Fontsize',11);

zlabel(sprintf('E(x,y,t = %1.2f)',t(j)),'Fontsize',11); axis ([0 1 0 1 0 max_e]);

pause(0.001); hold on;

if(j~=length(t)) delete(p1);

delete(p2);

end end

发表评论

电子邮件地址不会被公开。 必填项已用*标注