国产人妻人伦精品_欧美一区二区三区图_亚洲欧洲久久_日韩美女av在线免费观看

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

MATH4063代做、代寫C++編程設(shè)計

時間:2023-11-17  來源:合肥網(wǎng)hfw.cc  作者:hfw.cc 我要糾錯



1 MATH**3
The University of Nottingham
SCHOOL OF MATHEMATICAL SCIENCES
AUTUMN SEMESTER 2022-2023
MATH**3 - SCIENTIFIC COMPUTING AND C++
Coursework 1 - Released 30th October 2023, 4pm
Your work should be submitted electronically via the MATH**3 Moodle page by 12noon on Monday 20th
November (unless you have arranged an extension). Since this work is assessed, your submission must be
entirely your own work (see the University’s policy on Academic Misconduct). Submissions up to five working
days late will be marked, but subject to a penalty of 5% of the maximum mark per working day.
The marks for each question are given by means of a figure enclosed by square brackets, eg [20]. There are
a total of 100 marks available for the coursework and it contributes 45% to the module. The marking rubric
available on Moodle will be applied to each full question to further break down this mark.
You are free to name the functions you write as you wish, but bear in mind these names should be meaningful.
Functions should be grouped together in .cpp files and accessed in other files using correspondingly named
.hpp files.
All calculations should be done in double precision.
A single zip file containing your full solution should be submitted on Moodle. This zip file should contain three
folders called main, source and include, with the following files in them:
main:
• q1d.cpp
• q2c.cpp
• q3c.cpp
• q4b.cpp
source:
• vector.cpp
• dense_matrix.cpp
• csr_matrix.cpp
• linear_algebra.cpp
• finite_volume.cpp
include:
• vector.hpp
• dense_matrix.hpp
• csr_matrix.hpp
• linear_algebra.hpp
• finite_volume.hpp
Prior to starting the coursework, please download the CW1_code.zip from Moodle and extract the files. More
information about the contents of the files included in this zip file is given in the questions below.
Hint: When using a C++ struct with header files, the whole struct needs to be defined fully in the header file,
and the header file included in the corresponding .cpp file. Include guards should also be used.
MATH**3 Turn Over
2 MATH**3
In this coursework you will build a 2D finite volume solver for the following PDE boundary value problem
−𝛥w**6; + ∇ ⋅ (bw**6;) = 𝑓 (w**9;, 𝑦) ∈ 𝛺, (1)
w**6; = 𝑔, (w**9;, 𝑦) ∈ 𝜕𝛺, (2)
where 𝑓 ∶ 𝛺 → **7;, 𝑔 ∶ 𝜕𝛺 → **7; and b ∶ 𝛺 → **7;2
.
In order to solve this problem, you will first define a sparse matrix structure, then write functions to apply
the GMRES linear algebra solver and finally build and solve the linear system arising from the finite volume
approximation of (1)-(2).
1. Matrices arising from the discretisation of partial differential equations using, for example, finite volume
methods, are generally sparse in the sense that they have many more zero entries than nonzero ones.
We would like to avoid storing the zero entries and only store the nonzero ones.
A commonly employed sparse matrix storage format is the Compressed Sparse Row (CSR) format. Here,
the nonzero entries of an 𝑛 × 𝑛 matrix are stored in a vector matrix_entries, the vector column_no gives
the column position of the corresponding entries in matrix_entries, while the vector row_start of length
𝑛+1 is the list of indices which indicates where each row starts in matrix_entries. For example, consider
the following:
𝐴 =




8 0 0 2
0 3 1 0
0 0 4 0
6 0 0 7





matrix_entries = (8 2 3 1 4 6 7)
column_no = (0 3 1 2 2 0 3)
row_start = (0 2 4 5 7)
Note, in the above, C++ indexing has been assumed, i.e, indices begin at 0.
(a) In csr_matrix.hpp, define a C++ struct called csr_matrix to store a matrix in CSR format. In
addition to matrix_entries, column_no and row_start, you should store the number of rows of the
matrix explicitly.
(b) In csr_matrix.cpp, write a C++ function that will set up the matrix 𝐴 from above in CSR format.
Remember, if you are using dynamically allocated memory, then you should also have corresponding
functions that will deallocate the memory you have set up.
(c) In csr_matrix.cpp, write a C++ function that takes as input a matrix 𝐴 stored in CSR format and a
vector x and computes the product 𝐴x. The prototype for your function should be:
void MultiplyMatrixVector ( csr_matrix & matrix ,double* vector ,
double* productVector )
Hence, the input vector and the output productVector should be pointers to dynamically allocated
arrays. In particular, it should be assumed that productVector has been preallocated to the correct
size already.
(d) By setting a vector x = (4, −1, 3, 6)⊤, write a test program in q1d.cpp to compute and print to the
screen the product 𝐴x, where 𝐴 is the matrix given above.
[20 marks]
MATH**3
3 MATH**3
2. Suppose we wish to find x ∈ **7;𝑛
such that
𝐴x = b, (3)
where 𝐴 is an 𝑛 × 𝑛 matrix and b ∈ **7;𝑛
.
One algorithm for solving this problem is the (restarted) Generalised Minimal RESidual (GMRES) algorithm.
The method is too complicated to explain here, but works to quickly find approximations x𝑘 = x0 + y𝑘
where y𝑘 ∈ 𝒦𝑘 ∶= Span{𝐴q0
, 𝐴2q0 … 𝐴𝑘q0
} for 𝑘 = 1, 2, …. y𝑘 is chosen to minimise the residual
‖b − 𝐴x𝑘‖2
.
Here x0
is some initial guess vector and q0
is the normed initial residual
q0 =
b − 𝐴x0
‖b − 𝐴x0‖2
.
𝒦𝑘 is called a Krylov subspace of 𝐴.
The algorithm stops when ‖b − 𝐴x𝑘‖2 < tol for some termination tolerance tol. As the method becomes
very memory inefficient when 𝑘 is large, the method is restarted every so often and x𝑘 reset to be x0
.
An incomplete GMRES algorithm function PerformGMRESRestarted() has been written in
linear_algebra.cpp.
A key component of the GMRES algorithm is the Arnoldi iteration that seeks to find an orthonormal basis
of 𝒦𝑘. At the 𝑘th step of the iteration, the Arnoldi method constructs the following matrix decomposition
of 𝐴:
𝐴𝑄𝑘 = 𝑄𝑘+1𝐻̃
𝑘,
where the columns of 𝑄𝑘 (𝑄𝑘+1) contain the orthonormal basis of 𝒦𝑘 (𝒦𝑘+1, resp.) and 𝐻̃
𝑘 is a (𝑘+1)× 𝑘
upper Hessenberg matrix. That is, a matrix that is nearly upper triangular but has non-zero components
on the first subdiagonal.
The 𝑘th step of the Arnoldi algorithm is:
Algorithm 1 One step of the Arnoldi Iteration.
Require: 𝑘 > 0, 𝐴, 𝑄𝑘:
1: Let q𝑖 be the 𝑖th column of 𝑄𝑘.
2: Let h = {ℎ𝑖
}
𝑘+1
𝑖=1 be a vector of length 𝑘 + 1.
3: Compute q𝑘+1 = 𝐴q𝑘
4: for 𝑖 = 1, … , 𝑘 do
5: ℎ𝑖 = q𝑘+1 ⋅ q𝑖
.
6: q𝑘+1 = q𝑘+1 − ℎ𝑖q𝑖
.
7: end for
8: ℎ𝑘+1 = ‖q𝑘+1‖2
.
9: q𝑘+1 = q𝑘+1/ℎ𝑘.
10: 𝑄𝑘+1 = [𝑄𝑘, q𝑘+1].
11: return 𝑄𝑘+1 and h.
(a) In linear_algebra.cpp, write a C++ function which implements one step of the Arnoldi iteration
method defined above.
The function should have the following prototype
void PerformArnoldiIteration ( csr_matrix & matrix ,
dense_matrix & krylov_matrix , int k, double* hessenberg )
MATH**3 Turn Over
4 MATH**3
Here, matrix is 𝐴, k is the step of the iteration to perform, krylov_matrix is the matrix containing
the orthonormal basis, where each row is a basis vector. Upon entry, krylov_matrix should have 𝑘
rows and upon exit it should contain 𝑘 + 1 rows, with the new basis vector in the last row.
Finally, upon exit, hessenberg should contain h, which is the final column of 𝐻̃
𝑘. You may assume that
hessenberg has been preallocated to be of length 𝑘+1 before the call to PerformArnoldiIteration.
Your function should make use, where possible, of prewritten functions defined in dense_matrix.cpp
and vector.cpp. Your code should also make use of the matrix multiplication function from Q1.
Once you have written PerformArnoldiIteration() the GMRES function should function as intended.
Note: Storage of the basis functions in the rows of krylov_matrix, rather than in the columns,
improves efficiency of the code.
(b) In csr_matrix.cpp, write a C++ function that will read from a file a matrix already stored in CSR
format and a vector. You may assume the file structures are as in matrix1.dat and vector1.dat on
Moodle and you may use these data files to test your function.
(c) Write a test program in file q2c.cpp that will read in the matrix 𝐴 from matrix2.dat and the vector
x from vector2.dat, compute b = 𝐴x, then use PerformGMRESRestarted() with the default input
arguments to find an approximation x̂to x. At the end of the calculation, print to the screen the error
‖x − ̂ x‖2
.
[30 marks]
3. The file mesh.hpp contains a struct that defines a mesh data structure mesh for a general mesh comprising
axis-aligned rectangular cells. In particular, each cell in the mesh has an additional struct called
cell_information that contains, among other things, information about the cell neighbours. Familiarise
yourself with these data structures by looking in mesh.hpp.
mesh.cpp contains two functions that will generate meshes, they are:
• ConstructRectangularMesh() - this constructs a mesh on the rectangular domain 𝛺𝑅 = [𝑎, 𝑏] ×
[𝑐, 𝑑].
• ConstructLShapedMesh() - this constructs a mesh on the L-shaped domain 𝛺𝐿 = 𝛺𝑅\𝛺𝐶, where
𝛺𝐶 = [(𝑎 + 𝑏)/2, 𝑏] × [(𝑐 + 𝑑)/2, 𝑑].
(a) In finite_volume.cpp, write a C++ function that will create the storage for a matrix 𝐴 in CSR format
and a RHS vector F required for a cell-centred finite volume method for solving (1)-(2). You should
follow the procedure outlined in the Unit 6 lecture notes. As one of the inputs, your function should
take in a variable of type mesh.
(b) In csr_matrix.cpp, write a C++ function that will output to the screen a matrix stored in CSR format
in the same style as in matrix1.dat.
(c) In Q3c.cpp, write a program that will ask the user to supply the number of cells in each coordinate
direction of a rectangular mesh, sets up the mesh using ConstructRectangularMesh() then calls the
function from part (a) to set up the corresponding matrix and finally prints it to the screen using the
function from part (b).
[30 marks]
MATH**3
5 MATH**3
4. (a) In finite_volume.cpp, write a function that takes in a mesh, uses the function from Q3(a) to construct
𝐴 and F, then populates it with the correct entries to solve problem (1)-(2) using the cell-centred finite
volume method, as outlined in the Unit 6 notes. The function should also take as input the functions
𝑓(w**9;, 𝑦), b(w**9;, 𝑦) and the Dirichlet boundary function 𝑔(w**9;, 𝑦).
(b) In Q4b.cpp, write a main program to ask the user to select from the following problems and supply
the number of cells in each coordinate direction.
1. • Rectangular Mesh - 𝑎 = 0, 𝑏 = 1, 𝑐 = 0 and 𝑑 = 1;
• 𝑓(w**9;, 𝑦) = 1;
• 𝑔(w**9;, 𝑦) = 0;
• b = 0.
2. • L-shaped Mesh - 𝑎 = 0, 𝑏 = 1, 𝑐 = 0 and 𝑑 = 1;
• 𝑓(w**9;, 𝑦) = 8𝜋2
cos(2𝜋w**9;) cos(2𝜋𝑦);
• 𝑔(w**9;, 𝑦) = cos(2𝜋w**9;) cos(2𝜋𝑦);
• b = 0.
3. • Rectangular Mesh - 𝑎 = −1, 𝑏 = 1, 𝑐 = −1 and 𝑑 = 1;
• 𝑓(w**9;, 𝑦) = 1;
• 𝑔(w**9;, 𝑦) = 0;
• b = (10, 10)⊤.
4. • L-Shaped Mesh - 𝑎 = 0, 𝑏 = 1, 𝑐 = 0 and 𝑑 = 1;
• 𝑓(w**9;, 𝑦) = 0;

𝑔(w**9;, 𝑦) = {
1, w**9; = 0, 0.25 < 𝑦 < 0.75,
0, otherwise;
• b = (
50𝑦
√w**9;2+𝑦2
,
−50w**9;
√w**9;2+𝑦2
)

.
The code should then set up the linear system arising from the finite volume discretisation and solve
the system
𝐴uℎ = F
using PerformGMRESRestarted().
Finally, print to the screen the maximum value of uℎ.
Hint: Once you have computed uℎ you can output it to together with the mesh to a file using
OutputSolution() in mesh.cpp. plot_solution.py can then be used to plot the solution in Python.
Note, if you are unable to get the iterative solver from Q2 working, then you may create the finite volume
matrix 𝐴 as if it were a dense matrix (i.e store all the zero entries) and use the function
PerformGaussianElimination() from dense_matrix.cpp to solve the system of equations. This will incur
a small penalty. Note, an illustration of the use of PerformGaussianElimination() can be found in the
main program inside gaussian_elimination_test.cpp.
[20 marks]
MATH**3 End

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

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

    合肥圖文信息
    流體CFD仿真分析_代做咨詢服務(wù)_Fluent 仿真技術(shù)服務(wù)
    流體CFD仿真分析_代做咨詢服務(wù)_Fluent 仿真
    結(jié)構(gòu)仿真分析服務(wù)_CAE代做咨詢外包_剛強度疲勞振動
    結(jié)構(gòu)仿真分析服務(wù)_CAE代做咨詢外包_剛強度疲
    流體cfd仿真分析服務(wù) 7類仿真分析代做服務(wù)40個行業(yè)
    流體cfd仿真分析服務(wù) 7類仿真分析代做服務(wù)4
    超全面的拼多多電商運營技巧,多多開團助手,多多出評軟件徽y1698861
    超全面的拼多多電商運營技巧,多多開團助手
    CAE有限元仿真分析團隊,2026仿真代做咨詢服務(wù)平臺
    CAE有限元仿真分析團隊,2026仿真代做咨詢服
    釘釘簽到打卡位置修改神器,2026怎么修改定位在范圍內(nèi)
    釘釘簽到打卡位置修改神器,2026怎么修改定
    2025年10月份更新拼多多改銷助手小象助手多多出評軟件
    2025年10月份更新拼多多改銷助手小象助手多
    有限元分析 CAE仿真分析服務(wù)-企業(yè)/產(chǎn)品研發(fā)/客戶要求/設(shè)計優(yōu)化
    有限元分析 CAE仿真分析服務(wù)-企業(yè)/產(chǎn)品研發(fā)
  • 短信驗證碼 寵物飼養(yǎng) 十大衛(wèi)浴品牌排行 目錄網(wǎng) 排行網(wǎng)

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

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

    国产人妻人伦精品_欧美一区二区三区图_亚洲欧洲久久_日韩美女av在线免费观看
    宅男噜噜99国产精品观看免费| 黄色一级大片在线观看| 国内视频一区二区| 久久精品国产精品| 黄色一级片播放| 欧美成人精品在线| 成人中文字幕在线观看| 亚洲一区二区三区毛片| 国产超碰91| 欧美日韩高清免费| 精品国产一区三区| 91久久国产自产拍夜夜嗨| 日韩av不卡在线| 国产精品美乳一区二区免费| 国产欧美精品一区二区三区| 亚洲日本一区二区三区在线不卡| 久久免费观看视频| 男女视频网站在线观看| 欧美日韩不卡合集视频| 久久亚洲国产成人精品无码区| 日韩精品在线中文字幕| 国产精品高潮呻吟视频| 成人精品在线观看| 日韩欧美精品在线观看视频| 另类美女黄大片| 久久手机在线视频| 蜜桃视频成人| 天堂资源在线亚洲视频| 国产成人精品自拍| 成人免费网视频| 青青草视频国产| 一区二区三区我不卡| 国产xxxxx在线观看| 精品视频免费观看| 日本一区二区三区在线播放| 久久亚洲精品成人| 国产不卡av在线免费观看| 国产午夜福利视频在线观看| 日本最新一区二区三区视频观看| 国产精品日韩二区| 2019日本中文字幕| 国产在线精品一区二区三区 | 日韩精品手机在线观看| 久久成人综合视频| 久久久久免费视频| 波多野结衣综合网| 欧美高清性xxxxhd| 少妇久久久久久被弄到高潮| 国产人妻互换一区二区| 欧美在线一二三区| 亚洲a中文字幕| 久久国产精品影视| 久久久91精品国产一区不卡| 91国产丝袜在线放| 国产素人在线观看| 欧美日韩成人一区二区三区| 无码人妻h动漫| 中文字幕第一页亚洲| y97精品国产97久久久久久| 成人动漫在线观看视频| 国产在线资源一区| 日韩av播放器| 伊人网在线免费| 久久中国妇女中文字幕| 国产成人久久久| 久久久久久国产精品一区| 欧美亚州在线观看| 亚洲一区二区三区毛片| 国产精品入口日韩视频大尺度| 成人a在线观看| www.xxxx欧美| 久久九九国产视频| 7777精品久久久大香线蕉小说| 国产精品自拍网| 国产在线高清精品| 欧美性受xxx| 日韩av免费电影| 亚洲不卡中文字幕| 亚洲一区二区精品在线观看| 九九久久精品一区| 欧美精品生活片| 久久夜精品香蕉| 国产精品久久一| 精品国模在线视频| 日韩在线视频网站| 久久国产精品高清| 国产成人福利视频| 国产成人在线精品| 99在线视频免费观看| 粉嫩av免费一区二区三区| 国产女同一区二区| 国模精品视频一区二区| 蜜桃日韩视频| 国产一区二区视频在线免费观看| 欧美xxxx黑人又粗又长密月| 欧美亚洲国产另类| 欧美久久久久久| 激情久久av| 国产在线播放91| 国产无套粉嫩白浆内谢的出处| 久久久综合香蕉尹人综合网| 精品嫩模一区二区三区| 日本一区免费在线观看| 亚洲日本一区二区三区在线不卡| 精品久久蜜桃| 国产精品久久久久久久久久久久久久| 91精品免费看| 国产精品一区视频网站| 精品无人区一区二区三区竹菊| 热99精品只有里视频精品| 日韩一区国产在线观看| 亚洲黄色成人久久久| 亚洲一区美女| 亚洲人精品午夜射精日韩| 国产99久久精品一区二区 夜夜躁日日躁| 国产精品三级在线| 精品国内产的精品视频在线观看| 欧美性资源免费| 日本十八禁视频无遮挡| 欧美日韩一区二区视频在线| 蜜桃视频日韩| 国产伦精品一区二区三区在线| 国产精品国产三级国产aⅴ9色| 久久久久高清| 国产成人a亚洲精v品无码| 久久精品国产一区二区三区不卡| 久久久免费观看| 欧美激情区在线播放| 亚洲精品中文字幕乱码三区不卡| 日韩av不卡播放| 精品一区二区三区无码视频| 色综合五月天导航| 色偷偷9999www| 精品国产一区二区三区在线观看 | 国产精品久久7| 中文字幕色呦呦| 日本久久久精品视频| 麻豆视频成人| 久久人人看视频| 国产精品第8页| 视频一区二区综合| 精品日本一区二区| 国产高清在线不卡| 日韩在线欧美在线| 国产精品久久久久久久久久小说 | 99久久国产免费免费| 久热国产精品视频一区二区三区| 久久精彩视频| 欧美精品久久久久久久免费| 黄色成人在线看| 国产伦精品一区二区三区高清版 | 亚洲va韩国va欧美va精四季| 日本天堂免费a| 黄色片视频在线免费观看| 国产又爽又黄的激情精品视频| 国产视频999| 国产精品27p| 国产精品无码专区在线观看| 久久久久国产精品一区| 春日野结衣av| 女女同性女同一区二区三区91| 国产区精品视频| 91精品国产成人| 精品日本一区二区三区在线观看| 国产亚洲欧美一区二区| 久久国产亚洲精品无码| 中文字幕在线中文| 美女视频久久| 国产精品手机在线| 日韩国产小视频| 成人av.网址在线网站| 国产精品久久久久久久电影| 日韩精品在线视频免费观看| 91精品久久久久久久久青青 | 欧美日韩在线高清| 国产激情在线看| 一本久久a久久精品vr综合| 黄色一级片黄色| 久久久久久久久影视| 午夜精品一区二区三区在线视 | 国产成人无码精品久久久性色| 亚洲91精品在线亚洲91精品在线| 国产性生活免费视频| 国产精品久久一| 欧美日韩另类综合| 久久成人资源| 色欲av无码一区二区人妻| 97久久精品在线| 亚洲在线观看一区| 国产精品一区视频网站| 九九热精品视频| 国产原创精品| 久久亚洲影音av资源网| 精品一区二区日本| 国产精品日韩一区二区免费视频| 欧洲成人在线观看| 国产成人精品在线视频| 欧美日韩第二页| 国产精品三级网站| 国内精品久久久久久中文字幕|