加勒比久久综合,国产精品伦一区二区,66精品视频在线观看,一区二区电影

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

CSC3050代做、C++程序語言代寫
CSC3050代做、C++程序語言代寫

時(shí)間:2024-11-16  來源:合肥網(wǎng)hfw.cc  作者:hfw.cc 我要糾錯(cuò)



CSC3050 Project 3: RISC-V Simulator with RVV
1 Background
RISC-V, an open standard instruction set architecture (ISA), has rapidly become a
pivotal force in academic research and industrial development due to its flexibility
and open-source nature. Unlike proprietary ISAs, RISC-V offers the freedom for
developers to customize and extend the architecture, making it an ideal platform
for innovation in research, education, and the design of specialized hardware. One
of its most impactful extensions is the RISC-V Vector Extension (RVV), which
introduces efficient vector processing capabilities—a cornerstone of modern high performance computing. This is especially critical for applications like machine
learning, cryptography, and scientific simulations, where parallel data processing is
essential for improving computational speed and efficiency.
In this project, you are tasked with extending the QTRVSim RISC-V simulator
to support vector operations by implementing some of the RVV instructions.
After reviewing the number of cycles, you will get a feeling of how this is faster
than conducting element-wise operations.
Start early, this project can be time-consuming if you are not familiar with
simulators.
2 QTRVSim
QTRVSim is a RISC-V CPU simulator for education, where you can try its online
version on this link. Just in case you want to try different instructions, you can refer
to this page: RISC-V Instruction Set Specifications. A helpful video about using
QTRVSim can be found on Youtube
After familiarizing yourself with the QtRVSim manual, you can begin planning how
to integrate RVV instructions into the existing implementation. The simulator’s
source code, written in C++ and including both the core simulation functions and
graphical user interfaces (GUIs), can be found in the repository at this link. To test
your modifications, QtRVSim offers two methods for simulating assembly code: GUI
or command-line prompts.
Note: For this project, you are not required to modify any of the GUI components.
Your primary goal is to ensure that the RVV instructions function correctly when
using command-line prompts. Another objective in this project is to save the number
of cycles; the smaller the number you get, the better the score you get.
1
2.1 How to run
We give the example of running QTRVSim on Ubuntu with the terminal. You can
follow these steps:
1. We assume you already have the necessary packages for compiling cpp. If
not, you can easily find tutorial for them on the internet.
2. Install QT6 (QT5 does not work in most cases) with sudo apt install qt6-
base-dev. You might need sudo apt update first, and make sure you are
installing QT6, not QT5.
3. Download QTRVSim from the given repository.
4. Make a new directory for building files (mkdir build; cd build)
5. cmake -DCMAKE BUILD TYPE=Release /path/to/qtrvsim
6. make -j X, where X is the number of threads you want to use
7. If everything goes correctly, you can use ./target/qtrvsim cli –asm XXXXX.S
to run your .S file.
8. Via ./target/qtrvsim cli –help, you can check all helpful arguments.
3 RVV Instructions
In this assignment, you are required to implement the following RVV instructions
(suppose max vector size is **):
1. vsetvl rd, rs1, rs2: sets the length register vl to rs1 and rd, also sets the
register holding the type of vector to rs2 (8/16/**).
2. vadd.vv vd, vs2, vs1: adds two vectors vs2 and vs1, and stores the result
in vd
3. vadd.vx vd, vs2, rs1: adds rs1 to each element of vector vs2, and stores
the result in vd
4. vadd.vi vd, vs2, imm: adds the scalar value imm to each element of vector
vs2, and stores the result in vd
5. vmul.vv vd, vs2, vs1: conducts dot production on two vectors vs2 and vs1,
and stores the result in vd
6. vlw.v vd, (rs1): loads elements stored starting at rs1 into vector vd. The
length to load is dependent on the length stored at vl and the unit length
specified earlier.
7. vsw.v vs3, (rs1): stores vector elements of vs3 into memory starting at rs1.
The length to load is dependent on the length stored at vl and the unit length
specified earlier.
2
Figure 1: Matrix stored as vector
The whole point of this project is that, through the implementation, you will
understand why are vector operations is much faster than manipulate each ele ment individually. For example, writing 100 elements into memory will require 100
individual store instructions if in an element-wise manner. However, using vector
write, you only need to do one vector store instruction.
A detailed explanation of RVV instructions can be found at this manual. Reminder:
Do not forget to update vl when switching to operate on vectors with different
lengths.
4 Matrix Multiplication
After implementing and testing the aforementioned functionalities, you are required
to write a .S file that conduct matrix to matrix multiplication.
Ci,j =
X Ai,kBk,j
k
The actual matrix will be stored as a vector in memory, as shown in Figure 1. In
order to conduct vector multiplication, the size of the matrix n × m will be given.
We require you to generate two random matrices with sizes of 20 × 46 and
46 × 50 where elements can be of your own choice.
5 Tricks
There are several tricks you can apply to reduce cycle counts.
1. Reduction (required): This is similar to calculate the summation of a
vector, but more efficiently. The basic requirement is that you conduct this
summation on each element one-by-one, which leads to excessive cycles.
Another approach is to do binary split, i.e. repeatedly decompose the a vector
of size n into 2 vectors of size n//2, and then conduct vadd. There are also
other trick for conducting reduction, and you can explore any of them.
3
Possible reduction:
(a) scalar loop
(b) vector shift
(c) reduction instruction
(d) ...
2. Chaining (Extra credit): When conducting vector operations, it is not nec essary to wait for the entire instruction to complete. As shown in Figure 2, it
is possible to conduct VADD on the first element, right after obtaining the
first element of VMUL. A much better illustration can be found at Prof.Hsu’s
slides at this link.
Figure 2: chaining
6 Instruction on Implementation
The code involved in QTRVSim is quite complicated. Luckily, you only need to
focus on few script files.
1. src/machine/instruction.cpp: Edit this file to add new instructions. The
boxed fields are:
• instruction name
• instruction enum type (you can edit this by yourself; no need to follow
the example)
• input types (you can go through instruction.cpp to see what char is for
what type)
• machine code (hexadecimal)
• mask for effective bits for instruction (hexadecimal)
• customize flags (you can edit this by yourself; no need to follow the
example)
2. src/machine/core.cpp: Main pipeline of the simulator. You can find fetch,
decode, execute, writeback, memory in it, and edit these codes for your con venience.
4
3. src/machine/execute/alu.cpp: specify what to do for each alu operation.
You can create/edit these codes for your own convenience.
Other files might also interest you, but we will not go through all of them here.
Feel free to modify any codes as long as they work.
Notice: you need to use state.cycle count++; in core.cpp when needed.
Notice2: If you want to use v1,v2... as the vector register, you can modify
parse reg from string() in instruction.cpp.
Notice3: You might want to check dt.num rt, dt.num rd, dt.num rs for specific
register indexing.
Notice4: The largest vector register length is **. Load instruction will have a
memory latency of **. Besides, the cycles for multiplication is 4. (This means that,
to load a vector of length 10, the total cycles will be 1 + 1 + ** + 10 + 1 + 1 = 46)
7 Grading Criteria
The maximum score you can get for this lab is 100 points. We will first exam ine the correctness of your outputs to test cases. Since hard-coding each opera tion is fairly easy in C++, we will check the execution information, such as the
number of cycles, and content in memories/registers. Using of ChatGPT to im prove writing/generate codes/provide ideas is allowed and highly-recommended
as ChatGPT has become one of the best productivity tools.
Conducting ”higher-level” reduction or finishing the task with less number of cycles
will be granted with extra credit.
You are also required to compose a report, where you should show the results
of your test case executions. Besides you also need to show the total number of
cycles and explain where those cycles come from. (few sentences, no need to be
super specific.)
The deadline of this project is 23:59, Tuesday, 2024/11/19. For each day after
the deadline, 10 points will be deducted from your final score up to 30 points, after
which you will get 0 points.
Besides, if anyone is interested in developing with QT, you are more than welcome
to implement GUI support for RVV instruction. If done properly, you will earn extra
credits, and might contribute to future contents of this class.
Feel free to ask questions if you find anything confusing.
5
8 Submission
You should make sure your code compiles and runs. Then, it should be compressed
into a .zip file and submitted to BlackBoard. Any necessary instructions to
compile and run your code should also be documented and included. Finally, you are
also required to include a report containing the results of your test case execution.



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






 

掃一掃在手機(jī)打開當(dāng)前頁
  • 上一篇:ENGG1110代做、R編程語言代寫
  • 下一篇:代寫CCIT4020、代做python語言編程
  • 無相關(guān)信息
    合肥生活資訊

    合肥圖文信息
    2025年10月份更新拼多多改銷助手小象助手多多出評軟件
    2025年10月份更新拼多多改銷助手小象助手多
    有限元分析 CAE仿真分析服務(wù)-企業(yè)/產(chǎn)品研發(fā)/客戶要求/設(shè)計(jì)優(yōu)化
    有限元分析 CAE仿真分析服務(wù)-企業(yè)/產(chǎn)品研發(fā)
    急尋熱仿真分析?代做熱仿真服務(wù)+熱設(shè)計(jì)優(yōu)化
    急尋熱仿真分析?代做熱仿真服務(wù)+熱設(shè)計(jì)優(yōu)化
    出評 開團(tuán)工具
    出評 開團(tuán)工具
    挖掘機(jī)濾芯提升發(fā)動(dòng)機(jī)性能
    挖掘機(jī)濾芯提升發(fā)動(dòng)機(jī)性能
    海信羅馬假日洗衣機(jī)亮相AWE  復(fù)古美學(xué)與現(xiàn)代科技完美結(jié)合
    海信羅馬假日洗衣機(jī)亮相AWE 復(fù)古美學(xué)與現(xiàn)代
    合肥機(jī)場巴士4號線
    合肥機(jī)場巴士4號線
    合肥機(jī)場巴士3號線
    合肥機(jī)場巴士3號線
  • 短信驗(yàn)證碼 目錄網(wǎng) 排行網(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

    亚洲综合五月| 蜜臀av国产精品久久久久| 你懂的视频一区二区| 丝袜美腿亚洲一区| 精品大片一区二区| 欧美成人精品一级| 日韩精品dvd| 五月天综合网站| 精品国产网站| 欧美美女在线| 久久国内精品自在自线400部| 亚洲欧美日韩国产一区| 久久久久美女| 日韩精品免费视频一区二区三区| 麻豆国产欧美一区二区三区| 日韩精品永久网址| 国产亚洲欧洲| 亚洲二区精品| 亚洲性视频在线| 欧美视频二区欧美影视| 美女爽到高潮91| 色偷偷偷在线视频播放| 香蕉视频成人在线观看| 久久精品综合| 欧美日韩午夜| 偷拍亚洲精品| 国产精品视频一区视频二区 | 亚洲一区色图| 99精品国产福利在线观看免费| 9999国产精品| 日韩影院精彩在线| 黄色精品免费| 香蕉国产精品| 136国产福利精品导航网址| 丁香婷婷成人| 亚洲欧美日本国产| 少妇一区二区视频| 91精品在线免费视频| 美女www一区二区| 久久精品 人人爱| 国产成人福利夜色影视| 亚洲综合在线电影| 日韩电影二区| 中文字幕不卡三区视频| 操人在线观看| 欧美激情国产在线| 中文字幕在线免费观看视频| 免费中文字幕日韩欧美| 国产美女精品| 在线视频精品| 免费看欧美美女黄的网站| 视频一区二区中文字幕| 午夜亚洲影视| 手机精品视频在线观看| 石原莉奈在线亚洲二区| 日韩一区欧美二区| 美国毛片一区二区三区| 国产精品久久久久久久久妇女| 免费视频最近日韩| 漫画在线观看av| 精品欧美日韩精品| 国产亚洲欧美日韩精品一区二区三区| 日韩一区二区三区免费| 韩国精品视频在线观看| 久久一区二区三区四区五区| 日本欧美一区二区三区| 欧美日韩黄网站| 日韩二区三区四区| 国产精品主播在线观看| 色综合www| 亚洲精品1234| 日产午夜精品一线二线三线| 日韩欧美中文| 一区二区三区导航| 国产精品成人3p一区二区三区 | 欧美激情啪啪| 日本在线观看不卡视频| 99久久999| 91精品丝袜国产高跟在线| 久久久久蜜桃| 亚洲免费网站| 久久亚洲综合| 成人国产一区二区三区精品麻豆| 日韩国产欧美在线观看| 中文字幕日韩亚洲| 日韩精品视频中文字幕| 久久精品青草| 欧美中文日韩| 美女久久久久久| 99er精品视频| 青青草91久久久久久久久| 91久久午夜| 亚洲综合av一区二区三区| 国产精品大片免费观看| 2020国产精品极品色在线观看| 欧美色婷婷久久99精品红桃| 日本大胆欧美人术艺术动态| 青青草国产一区二区三区| 在线高清欧美| 精品伊人久久久| 视频一区视频二区在线观看| 精品乱码一区二区三区四区| 国产亚洲一区| 国精品一区二区三区| 另类激情视频| 日韩高清中文字幕一区| 7777精品| 人禽交欧美网站| 欧美a级一区二区| 国产美女亚洲精品7777| 99在线精品免费视频九九视| 日韩av首页| 日韩av电影天堂| 女人香蕉久久**毛片精品| 亚洲人成在线网站| 国产一区二区三区四区二区| 欧美高清一区| 国产亚洲欧美日韩精品一区二区三区 | 精品国产一区二区三区不卡蜜臂 | 国产精品久久亚洲不卡| 亚洲福利网站| 在线午夜精品| 日本欧美一区二区三区乱码| 秋霞影院一区二区三区| 欧美国产小视频| 成人在线视频国产| 99精品美女| 免费一二一二在线视频| 亚洲精品中文字幕99999| jlzzjlzz亚洲女人| 国产亚洲欧美日韩精品一区二区三区| 婷婷综合福利| 蜜桃av一区二区三区电影| 亚洲精品韩国| 国产二区精品| 99精品视频免费| 久久精品99久久无色码中文字幕| 日韩国产欧美| 国产精品xxxav免费视频| 欧美freesextv| 日韩三区视频| 阿v视频在线观看| 精品成人18| 亚洲精品**中文毛片| 日韩精品导航| 色男人天堂综合再现| 国产一区三区在线播放| 蜜桃伊人久久| 日韩精品免费一区二区夜夜嗨| 视频一区二区中文字幕| 亚洲黄色录像| 91一区在线| 国产欧美自拍一区| 99精品视频免费| 女同性一区二区三区人了人一| 麻豆精品新av中文字幕| 婷婷亚洲五月| 欧美中文高清| 漫画在线观看av| 欧美xxxx在线| 日韩精品亚洲专区| 欧美精品一区二区三区久久久竹菊| 亚洲精品在线二区| 亚洲免费综合| 日韩国产在线不卡视频| 精精国产xxx在线视频app| 精品视频高潮| 日本va欧美va瓶| 老妇喷水一区二区三区| 日韩深夜影院| 99久久久国产精品免费调教网站 | 亚洲女色av| 精品久久视频| 久久影视三级福利片| 亚洲综合另类| 国产成人精品亚洲线观看| 欧美永久精品| 亚洲欧美春色| 加勒比色综合久久久久久久久| 久久精品国产第一区二区三区| 欧美日韩国产高清| 久久国际精品| 日韩和的一区二区| 日韩中文字幕区一区有砖一区| 777久久精品| 亚洲精品乱码| 国产精品一二| 亚洲天堂黄色| 亚洲成aⅴ人片久久青草影院| av在线视屏| 999精品在线| 亚洲调教一区| 久久一区国产| 国产污视频在线播放| 蜜臀av免费一区二区三区| 亚洲第一福利专区| 麻豆专区一区二区三区四区五区| 爽好多水快深点欧美视频| 亚洲不卡av不卡一区二区| 国产精品一区二区99|