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

合肥生活安徽新聞合肥交通合肥房產生活服務合肥教育合肥招聘合肥旅游文化藝術合肥美食合肥地圖合肥社保合肥醫院企業服務合肥法律

CSC3050代做、C++程序設計代寫
CSC3050代做、C++程序設計代寫

時間:2024-11-21  來源:合肥網hfw.cc  作者:hfw.cc 我要糾錯



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.
6

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




 

掃一掃在手機打開當前頁
  • 上一篇:24LLP109代做、代寫c/c++編程語言
  • 下一篇:代寫MATH36031、Python程序設計代做
  • 無相關信息
    合肥生活資訊

    合肥圖文信息
    流體仿真外包多少錢_專業CFD分析代做_友商科技CAE仿真
    流體仿真外包多少錢_專業CFD分析代做_友商科
    CAE仿真分析代做公司 CFD流體仿真服務 管路流場仿真外包
    CAE仿真分析代做公司 CFD流體仿真服務 管路
    流體CFD仿真分析_代做咨詢服務_Fluent 仿真技術服務
    流體CFD仿真分析_代做咨詢服務_Fluent 仿真
    結構仿真分析服務_CAE代做咨詢外包_剛強度疲勞振動
    結構仿真分析服務_CAE代做咨詢外包_剛強度疲
    流體cfd仿真分析服務 7類仿真分析代做服務40個行業
    流體cfd仿真分析服務 7類仿真分析代做服務4
    超全面的拼多多電商運營技巧,多多開團助手,多多出評軟件徽y1698861
    超全面的拼多多電商運營技巧,多多開團助手
    CAE有限元仿真分析團隊,2026仿真代做咨詢服務平臺
    CAE有限元仿真分析團隊,2026仿真代做咨詢服
    釘釘簽到打卡位置修改神器,2026怎么修改定位在范圍內
    釘釘簽到打卡位置修改神器,2026怎么修改定
  • 短信驗證碼 寵物飼養 十大衛浴品牌排行 suno 豆包網頁版入口 wps 目錄網 排行網

    關于我們 | 打賞支持 | 廣告服務 | 聯系我們 | 網站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

    Copyright © 2025 hfw.cc Inc. All Rights Reserved. 合肥網 版權所有
    ICP備06013414號-3 公安備 42010502001045

    国产人妻人伦精品_欧美一区二区三区图_亚洲欧洲久久_日韩美女av在线免费观看
    国产欧美精品日韩精品| 欧美精品久久久久久久久久| 精品视频无码一区二区三区| 久久国产精品免费观看| 亚洲砖区区免费| 国产女主播一区二区三区| 国产精品第一视频| 亚洲欧美精品| 国产美女精品视频| 蜜臀久久99精品久久久无需会员| 国模吧一区二区| 国产激情久久久久| 色偷偷噜噜噜亚洲男人| 性欧美精品一区二区三区在线播放| 欧美在线亚洲一区| 国产v片免费观看| 亚洲 中文字幕 日韩 无码| 99福利在线观看| 国产精品手机视频| 亚洲色欲久久久综合网东京热| 日本不卡一二三区| 久久全球大尺度高清视频| 另类天堂视频在线观看| 国语对白做受xxxxx在线中国| 久久久成人精品视频| 今天免费高清在线观看国语| 国产精品久久国产精品99gif| 色欲色香天天天综合网www| 91九色丨porny丨国产jk| 午夜精品久久久99热福利| 国产精品2018| 久久综合国产精品台湾中文娱乐网| 免费av在线一区二区| 久久久久久a亚洲欧洲aⅴ| 午夜精品亚洲一区二区三区嫩草| 97精品伊人久久久大香线蕉| 欧美激情视频在线观看| 欧美在线视频导航| 久久精品视频在线| 国产一区二区三区高清| 久久999免费视频| 欧美在线性视频| 国产精品视频永久免费播放| 性欧美亚洲xxxx乳在线观看 | 久久久久久久久综合| 国内精品免费午夜毛片| 亚洲在线视频一区二区| 国产激情久久久久| 一级做a爰片久久| 91精品视频一区| 国产aaa一级片| 99久久免费观看| 日韩精品一区二区三区丰满| 国产精品欧美在线| 欧美在线日韩在线| 欧美精品日韩www.p站| yellow视频在线观看一区二区| 国产精品视频久| 国产日产欧美一区二区| 天堂av一区二区| 国产精品我不卡| av在线不卡观看| 伊人久久大香线蕉成人综合网| 欧美国产激情视频| 久久精品国产清自在天天线| 日韩人妻一区二区三区蜜桃视频| 国产精品久久中文| 麻豆一区二区三区在线观看| 亚洲一区二区三区乱码aⅴ | 国产欧美在线看| 天堂av在线中文| 成人短视频在线观看免费| 国产精品成人观看视频国产奇米| 国产伦理一区二区三区| 人人妻人人澡人人爽精品欧美一区 | 午夜精品视频网站| 国产精品手机视频| 91av福利视频| 久久久久久尹人网香蕉| 日本新janpanese乱熟| 国产精品伦子伦免费视频| 91精品成人久久| 国产网站免费在线观看| 全黄性性激高免费视频| 国产精品无av码在线观看| 黄色影院一级片| 熟妇人妻va精品中文字幕| 久久免费看毛片| 日本一区二区三区四区五区六区| 国产精品久久久久久免费观看| 欧美 国产 精品| 国产精品国模大尺度私拍| 欧美视频观看一区| 日本欧美色综合网站免费| 美女扒开尿口让男人操亚洲视频网站| 国产中文欧美精品| 亚洲色成人www永久在线观看 | 色综合久久久888| 国产精品一区二区三区精品| 中文字幕第一页亚洲| 国产成人精品综合久久久| 国产精品99久久久久久久久久久久| 手机看片日韩国产| 少妇精69xxtheporn| 欧美日韩在线播放一区二区| 亚洲不卡中文字幕无码| 欧美激情精品久久久久久| 久久亚洲精品无码va白人极品| 日韩欧美亚洲天堂| 国产精品美女诱惑| 久久涩涩网站| 777国产偷窥盗摄精品视频| 波多野结衣综合网| 高清欧美性猛交| 日本黄网站色大片免费观看| 国产精品女主播| 高清欧美性猛交xxxx| 日日橹狠狠爱欧美超碰| 国产精品视频99| 久久久久久亚洲精品中文字幕| 久在线观看视频| 久久伊人一区| 国产成人亚洲综合91精品| 国产成人在线亚洲欧美| 久久99精品久久久久久青青日本| 国产亚洲欧美一区二区三区| 黄色av网址在线播放| 激情内射人妻1区2区3区| 国内成人精品视频| 国产又爽又黄的激情精品视频| 国内视频一区二区| 蜜桃免费区二区三区| 精品少妇一区二区三区在线| 国产综合在线观看视频| 日韩在线一级片| 欧美一区二区大胆人体摄影专业网站 | 美日韩精品免费视频| 欧美成人一区在线| 国产福利视频一区| 久久资源av| 国产精品亚洲激情| 国产伦精品一区二区三区| 欧美尤物巨大精品爽| 欧美在线激情网| 国内一区在线| 粉嫩av一区二区三区免费观看 | 国产亚洲情侣一区二区无| 品久久久久久久久久96高清| 一区二区三区国产福利| 亚洲色成人www永久在线观看| 天堂v在线视频| 欧美专区国产专区| 丁香六月激情婷婷| 日本一区免费在线观看| 亚洲国产精品一区二区第四页av| 国产精品视频一区二区高潮| 久久久人人爽| 日韩在线中文字幕| 久久亚洲影音av资源网| 精品国产欧美成人夜夜嗨| 国产精品久久久久久久一区探花| 日韩一区二区在线视频| 久久夜精品va视频免费观看| 亚洲一区二区中文| 欧美激情欧美激情在线五月| 午夜啪啪免费视频| 欧美久久综合性欧美| 日本高清不卡三区| 欧美精品久久久久久久自慰| 日韩免费黄色av| 免费观看国产精品视频| 97久久超碰福利国产精品…| 九九热久久66| 欧美日韩国产91| 欧美在线一区二区三区四| 热久久免费国产视频| 日本亚洲欧美成人| 免费av一区二区三区| 久久久亚洲福利精品午夜| 国产精品久久av| 日韩av一区二区三区在线| 色一情一乱一伦一区二区三区| 欧美日韩亚洲在线| 99九九视频| 国产精品久久久久av免费| 性欧美精品一区二区三区在线播放| 蜜臀av.com| 久草在在线视频| 日韩一级裸体免费视频| 久久久久日韩精品久久久男男| 九九九九久久久久| 久久久久久久久久久成人| 久久夜色精品国产| 日韩欧美精品免费| 99国产在线观看| 久久偷窥视频| 欧美精品一二区| 青青草国产精品视频| 欧美精品一区二区三区三州| 69av在线播放|