99爱在线视频这里只有精品_窝窝午夜看片成人精品_日韩精品久久久毛片一区二区_亚洲一区二区久久

合肥生活安徽新聞合肥交通合肥房產(chǎn)生活服務(wù)合肥教育合肥招聘合肥旅游文化藝術(shù)合肥美食合肥地圖合肥社保合肥醫(yī)院企業(yè)服務(wù)合肥法律

ECM3446代做、代寫Python/C++編程
ECM3446代做、代寫Python/C++編程

時間:2025-02-09  來源:合肥網(wǎng)hfw.cc  作者:hfw.cc 我要糾錯



ECM3446: CA
This continuous assessment is for the ECM3446 version of the High Performance Computing
module. If you are an undergraduate student you should follow these in- structions. If you are a
student on an MSc programme please refer to the “ECMM461: Continuous assessment 1”
instructions instead.
1 The Atmospheric Boundary Layer
The part of the Earth’s atmosphere nearest the surface is known as the “Atmospheric Boundary
Layer”, and in this part of the atmosphere the wind speed increases with height. This causes
material emitted from a chimney to be advected at di↵erent horizontal speeds depending on its
height. Figure 1 shows material from a chimney being advected by the wind.
Figure 1: Material emitted from a chimney being advected by a horizontal wind
The wind in the Atmospheric Boundary Layer can be approximated as a horizontal velocity which
depends only on the height (z) and zero vertical velocity. The horizontal velocity as a function of height
vx(z) can be represented by a logarithmic profile
(1)
where u is a parameter called the “friction velocity”, z0 is a parameter called the “roughness
length”, and = 0.41 is a constant called Von K´arm´an’s constant.
2 The assignment
In this assignment you will calculate a numerical solution to the advection equation to simulate the
movement of a cloud of material in the atmospheric boundary layer. There are four parts to this assignment:
• Task 1: For the first part of this assignment you will parallelise a program which calculates a
numerical solution to the 2D advection equation. You have been provided with the program
1
-
-ECM3446: CA
and you will need to parallelise it using OpenMP. This part of the assignment is described
in Section 2.1.
• Task 2: For the second part of this assignment you will modify the program to change
the parameters of the test problem into a more realistic configuration. This is described in
Section 2.2.
• Task 3: For the third part of this assignment you will add a logarithmic velocity profile to
the program. This is described in Section 2.3.
• Task 4: For the fourth part of the assignment you will calculate the horizontal profile of the
advected material by calculating a vertical average. This is described in Section 2.4.
This assignment assesses the following Intended Learning Outcomes:
• Demonstrate skills in parallel processing algorithm design and the practical implementation
of such algorithms
• Demonstrate an awareness of numerical e↵ects and the influence of floating point number
representation in high-performance computing applications.
• Interpret an informal requirement specification
• Systematically analyse information and make appropriate design choices
2.1 Task 1: Parallelising the program
The advection equation for a two-dimensional scalar field u(x, y) is
(2)
where vx and vy are the velocities in the x and y direction, respectively. You have been
provided with a C program which calculates a numerical solution to the advection equation
for a two- dimensional scalar field u(x, y) using finite di↵erence approximations. The program
uses one-sided di↵erences to calculate the spatial derivatives
dy (4)
where ui,j is the value of the scalar field u(x, y) at grid point (i, j), dx is the spacing of grid points
in the x direction and dy is the spacing of grid points in the y direction. The solution starts
from specified initial conditions at time t = 0 and is updated from time t to time t + t using
forward-Euler time steps
t (5)
The program uses 1000 ⇥ 1000 grid points covering a unit square computational domain 0 
x  1.0 and 0  y  1.0. The initial conditions are a Gaussian given by the expression
(6)
The Gaussian is centred at x0 = 0.1, y0 = 0.1 and has a width x = y = 0.03. The boundary
conditions are u = 0 on all boundaries. The program calculates 1500 time steps, and the time step
size is calculated from the Courant condition with a CFL number of 0.9. The velocities in the x
and y directions are vx = 0.01 and vy = 0.01 respectively.
The first part of the assignment is to parallelise the program provided using OpenMP. There
are 10 loops or loop nests (a loop over j inside a loop over i) in the program and these have been
identified with a comment of the form
2ECM3446: CA
/* LOOP N */
where N is an integer between 1 and 10 inclusive. For each loop or loop nest you should decide
whether it can be correctly parallelised by adding an OpenMP directive:
• If the loop can be correctly parallelised then you should parallelise it by adding an OpenMP
directive, ensuring that all variables are correctly scoped. You do not need to scope variables
which have the const qualifier.
• If the loop cannot be parallelised then you should add a comment in the program to say that
the loop cannot be parallelised and explain why.
To build the serial program in ISCA use the command
gcc -o advection2D -std=c99 advection2D.c -lm
To build the program with OpenMP enabled in ISCA use the command
gcc -fopenmp -o advection2D -std=c99 advection2D.c -lm
A gnuplot script which plot the final values of u(x, y) has been provided.
The parallelised version of the program must produce exactly the same output as
the original program.
2.2 Task 2: Modifying the calculation
In this section you will modify the example program to change the test problem so that it more
closely resembles a cloud of material emitted from a chimney. This requires changing the size of
the computational domain, the initial conditions, the velocities and the number of time steps.
In the following instructions distances are measured in metres (m) and velocities in metres per
second (m/s).
• The test problem uses a computational domain which is a unit square (it covers the range
0  x  1.0 and 0  y  1.0). Change the computational domain so that it covers the range
0  x  30.0 m and 0  y  30.0 m
• For this calculation we require the Gaussian to be on the left hand side of the domain and
vertically centred. Change the centre of the Gaussian to x0 = 3.0 m, y0 = 15.0 m
• The cloud of material will have a larger vertical extent than horizontal extent. This will be
represented by a Gaussian which has di↵erent widths in the x and y directions. Change the
widths of the Gaussian specified in the initial conditions to x = 1.0 m and y = 5.0 m
• The material in the atmospheric boundary layer advects horizontally but not vertically.
Change the horizontal velocity to vx = 1.0 m/s and change the vertical velocity to vy = 0.
• Change the maximum number of time steps to 800 so that the material does not advect out
of the computational domain.
After you have made these changes re-compile and re-run the program. If necessary update
the OpenMP directives to ensure that the program produces identical results with and without
OpenMP.
Now plot the initial and final values of u(x, y). The initial values are in the file initial.dat
and the final values are in the file final.dat. You can use the example gnuplot script provided
but you will need to change the axis limits to match the new computational domain size. Plots of
the initial and final values of u(x, y) are shown in Figure 2 for comparison.
3ECM3446: CA
Figure 2: Initial (left) and final (right) values of u(x, y) from the calculation in Section 2.2
2.3 Task 3: Adding vertical shear
In this section you will modify the program so that the horizontal velocity varies with height
according to the logarithmic profile given in equation 1. The logarithmic profile should only be
used if z is greater than the roughness length z0. If z > z0 calculate the horizontal velocity using
equation 1, and if z  z0 set the horizontal velocity to zero. The parameters of the profile should
be set to u⇤ = 0.2 m/s, z0 = 1.0 m and  = 0.41.
In the program the variable y represents the height z in equation 1. The computational domain,
the initial conditions and the number of time steps should be kept at the values specified in the
previous section (Section 2.2).
Modify the horizontal velocity as described above and re-run the program. If necessary update
the OpenMP directives to ensure that the program produces identical results with and without
OpenMP.
Now plot the final values of u(x, y) (the initial values are the same as in the previous
section). Plots of the initial and final values of u(x, y) are shown in Figure 3.
Figure 3: Initial (left) and final (right) values of u(x, y) from the calculation in Section 2.3
2.4 Task 4: Calculating the vertically averaged distribution
In this last section you should calculate the vertically averaged distribution of u(x, y) at the end
of the calculation in Section 2.3. The vertical average should cover the whole vertical domain but
should not include the boundary values. The code you add to the program does not need to be
4ECM3446: CA
parallelised. Plot the vertically averaged values of u as a function of x using a line
graph.
3 Deliverables
The deliverables for this assignment are the source code for the program with your modifications,
and the four plots showing your results:
1. Source code for the final version of the program. The program should include the OpenMP
directives added in Section 2.1 with any changes required to ensure the modified program
continues to work correctly. The computational domain, the initial conditions, the velocities
and the number of time steps should be set to the values used in Section 2.3.
2. Four plots showing the output from running the program. The required plots are:
• A plot of the initial conditions u(x, y) from Section 2.2
• A plot of the final values of u(x, y) from Section 2.2
• A plot of the final values of u(x, y) from Section 2.3
• A plot showing the vertically averaged profile of u from Section 2.4
The plots may be generated using the gnuplot script provided, or alternative plotting software
of your choice provided the data values in the plot are clearly represented. Your plots should
be delivered as PNG or PDF files.
The deliverables should uploaded to ELE a single zip or tar file containing the
source code for the final version of the program, and the four plots. The deadline for
submission is 12 noon 20 February 2025.
4 Mark scheme
A total of 100 marks are available for this assignment:
1. Task 1: Parallelising the program (30 marks)
(a) For each of the 10 loops or loop nests identified in the program there are two marks to
be awarded according to the following criteria:
• The loop has been correctly identified as either one that can be parallelised or one
that cannot be parallelised (1 mark)
• If the loop can be parallelised then an appropriate OpenMP directive has been
added which unambiguously and correctly scopes all variables. Variables with the
const qualifier do not need to be scoped (1 mark)
OR
• If the loop cannot be parallelised then a comment has been added with a correct
explanation of why the loop cannot be parallelised (1 mark).
(b) An additional 10 marks are awarded if the parallelised program produces results which
exactly match the original serial program.
2. Task 2: Modifying the calculation (20 marks)
10 marks are awarded for correctly modifying the computational domain, the initial conditions
 and the number of time steps, as specified in Section 2.2. 5 marks are awarded for the
plot of the initial conditions and 5 marks are awarded for the plot of the final results.
3. Task 3: Adding vertical shear (25 marks)
20 marks are awarded for correctly modifying the velocity profile as specified in Section 2.3.
5 marks are awarded for the plot of the final results.
5ECM3446: CA
4. Task 4: Calculating the vertically averaged distribution (25 marks)
20 marks are awarded for correctly modifying the program to calculate the vertically averaged
distribution of u as specified in Section 2.4. 5 marks are awarded for the plot of the final
results.


請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp



 

掃一掃在手機打開當(dāng)前頁
  • 上一篇:代寫CCBS4020、代做c/c++,Python設(shè)計程序
  • 下一篇:代寫INT2067、代做Python編程語言
  • 無相關(guān)信息
    合肥生活資訊

    合肥圖文信息
    急尋熱仿真分析?代做熱仿真服務(wù)+熱設(shè)計優(yōu)化
    急尋熱仿真分析?代做熱仿真服務(wù)+熱設(shè)計優(yōu)化
    出評 開團工具
    出評 開團工具
    挖掘機濾芯提升發(fā)動機性能
    挖掘機濾芯提升發(fā)動機性能
    海信羅馬假日洗衣機亮相AWE  復(fù)古美學(xué)與現(xiàn)代科技完美結(jié)合
    海信羅馬假日洗衣機亮相AWE 復(fù)古美學(xué)與現(xiàn)代
    合肥機場巴士4號線
    合肥機場巴士4號線
    合肥機場巴士3號線
    合肥機場巴士3號線
    合肥機場巴士2號線
    合肥機場巴士2號線
    合肥機場巴士1號線
    合肥機場巴士1號線
  • 短信驗證碼 豆包 幣安下載 AI生圖 目錄網(wǎng)

    關(guān)于我們 | 打賞支持 | 廣告服務(wù) | 聯(lián)系我們 | 網(wǎng)站地圖 | 免責(zé)聲明 | 幫助中心 | 友情鏈接 |

    Copyright © 2025 hfw.cc Inc. All Rights Reserved. 合肥網(wǎng) 版權(quán)所有
    ICP備06013414號-3 公安備 42010502001045

    99爱在线视频这里只有精品_窝窝午夜看片成人精品_日韩精品久久久毛片一区二区_亚洲一区二区久久

          国产精品一香蕉国产线看观看 | 国产一区二区三区久久悠悠色av | 亚洲欧美国产视频| 亚洲一区二区三| 欧美一区二区三区日韩视频| 香蕉成人伊视频在线观看| 久久国产福利国产秒拍| 久久综合五月天婷婷伊人| 欧美刺激性大交免费视频| 欧美日韩一区二区在线观看视频| 欧美午夜电影完整版| 国产啪精品视频| 亚洲日本理论电影| 亚洲欧美综合网| 免费久久99精品国产自在现线| 欧美激情一区| 国产亚洲欧美另类一区二区三区| 亚洲国产精品久久91精品| 亚洲一区亚洲| 免费在线看成人av| 国产日韩精品一区观看 | 久久精品国产精品亚洲精品| 免费在线观看精品| 国产精品日本欧美一区二区三区| 激情综合在线| 亚洲无玛一区| 欧美国产极速在线| 国产精品一区二区黑丝| 亚洲激情在线观看| 久久精品噜噜噜成人av农村| 欧美日韩综合久久| 亚洲国产精品久久91精品| 欧美在线观看天堂一区二区三区| 欧美精品免费播放| 精品88久久久久88久久久| 午夜精品区一区二区三| 久久综合999| 国产午夜亚洲精品羞羞网站 | 亚洲人永久免费| 久久这里只精品最新地址| 国产精品一区二区在线| 中文精品在线| 欧美日韩在线播放| 亚洲免费电影在线| 欧美激情a∨在线视频播放| 精品不卡一区二区三区| 欧美在线关看| 国产日韩一级二级三级| 亚洲主播在线| 国产精品伊人日日| 午夜精品久久久久久久99水蜜桃| 欧美色欧美亚洲另类二区| 亚洲日本成人网| 欧美精品一区二区三区在线播放| 在线国产精品一区| 免费欧美视频| 亚洲精品在线观看免费| 欧美交受高潮1| aa级大片欧美三级| 欧美日韩亚洲精品内裤| 亚洲精品中文字幕在线观看| 欧美精品在线一区二区| 亚洲精品一二三| 欧美日韩视频免费播放| 亚洲天堂免费观看| 国产精品理论片在线观看| 亚洲你懂的在线视频| 国产热re99久久6国产精品| 午夜国产一区| 一区二区在线观看视频| 欧美国产第一页| 亚洲裸体视频| 国产精品入口麻豆原神| 久久精品2019中文字幕| 在线观看亚洲| 欧美日韩亚洲91| 先锋影音久久久| 激情成人综合网| 欧美日韩成人综合在线一区二区| 亚洲视频在线一区| 国产在线观看一区| 欧美bbbxxxxx| 亚洲综合精品一区二区| 一区在线视频| 欧美日韩国产综合久久| 亚久久调教视频| 91久久久亚洲精品| 国产精品看片资源| 久久综合伊人77777麻豆| 9国产精品视频| 国产一区二区精品在线观看| 欧美激情一区二区三级高清视频 | 国产美女精品视频免费观看| 久久午夜视频| 亚洲婷婷综合色高清在线| 一区二区三区在线免费播放| 欧美日韩国产影片| 久久久久天天天天| 亚洲午夜影视影院在线观看| 亚洲国产成人久久| 国产精品永久免费| 欧美激情1区| 久久嫩草精品久久久精品一| 亚洲视频图片小说| 亚洲国产精品久久久久秋霞不卡| 国产精品揄拍一区二区| 欧美精品二区三区四区免费看视频| 亚洲欧美久久久久一区二区三区| 亚洲国产美国国产综合一区二区| 国产精品无码永久免费888| 欧美黄色aa电影| 久久网站热最新地址| 亚洲女性裸体视频| 999亚洲国产精| 亚洲欧洲精品一区二区三区| 国产综合久久| 国产欧美一区二区三区在线老狼| 欧美日韩综合在线| 欧美绝品在线观看成人午夜影视| 久久久综合视频| 欧美一区二区在线播放| 国产精品99久久久久久人| 亚洲精品一区二区三| 亚洲福利视频三区| 激情视频一区| 国内精品**久久毛片app| 国产精自产拍久久久久久蜜| 欧美性做爰毛片| 国产精品国产a级| 国产精品成人观看视频国产奇米| 欧美日韩一区二区三区| 欧美日韩精品一区二区在线播放| 欧美精品一卡二卡| 欧美精品系列| 欧美亚洲成人免费| 国产精品老牛| 国产视频在线观看一区二区| 国产日韩1区| 激情综合自拍| 亚洲高清视频一区| 亚洲精品一区二区在线| 一本色道久久综合亚洲二区三区 | 激情文学综合丁香| 在线观看不卡| 99视频热这里只有精品免费| 一区二区不卡在线视频 午夜欧美不卡在 | 久久www成人_看片免费不卡| 久久精品一区二区三区中文字幕| 久久精品在线视频| 卡通动漫国产精品| 欧美精品一区在线发布| 国产精品电影观看| 国产视频一区在线观看| 经典三级久久| 日韩视频在线免费| 亚洲尤物影院| 久久一二三四| 欧美日韩免费高清| 国产美女一区二区| 在线精品国产欧美| 日韩视频一区二区| 午夜日韩在线观看| 老色鬼精品视频在线观看播放| 欧美成人一区在线| 国产精品美女999| 在线观看视频日韩| 亚洲一区在线直播| 久久综合五月| 欧美午夜精品久久久久免费视| 国产欧美丝祙| 91久久黄色| 欧美在线三区| 欧美日韩国产综合一区二区| 国产亚洲高清视频| 99精品视频免费| 久久免费黄色| 国产精品久久久久久久久免费桃花 | 在线观看视频一区| 亚洲一区图片| 欧美另类极品videosbest最新版本| 国产精品视频男人的天堂| 亚洲黄色av一区| 久久精品91| 国产精品视频免费| 亚洲伦理一区| 免费不卡欧美自拍视频| 国产偷久久久精品专区| 99精品国产在热久久| 老色鬼精品视频在线观看播放| 国产精品久久久久天堂| 亚洲乱码国产乱码精品精可以看 | 亚洲系列中文字幕| 欧美大片免费久久精品三p | 欧美日韩亚洲综合| 亚洲国产综合在线看不卡| 久久午夜羞羞影院免费观看| 国产亚洲精品美女| 亚洲影视在线| 欧美午夜寂寞影院| 一本久久综合亚洲鲁鲁|