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

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

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程序設計代做
  • 無相關信息
    合肥生活資訊

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

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

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

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

          9000px;">

                综合久久一区二区三区| 26uuu国产一区二区三区| 日韩精品一区二区三区四区| 日韩和的一区二区| 日韩三级高清在线| 国产成人综合网| ●精品国产综合乱码久久久久| 亚洲成人综合在线| 亚洲国产精品天堂| 午夜精品福利一区二区三区蜜桃| 亚洲精品高清在线| 亚洲一区二区在线观看视频| 亚洲一区二区三区激情| 亚洲高清久久久| 午夜成人免费视频| 久久99蜜桃精品| 国产伦精品一区二区三区免费| 精品午夜久久福利影院| 国产精品一区二区在线播放| 高清国产一区二区| 99久久精品一区| 欧美亚洲国产bt| 8x8x8国产精品| 久久品道一品道久久精品| 久久综合久久99| 久久免费偷拍视频| 亚洲欧美综合色| 五月婷婷另类国产| 国产精品一区二区在线播放 | 另类欧美日韩国产在线| 国产电影精品久久禁18| av一区二区三区| 日本久久精品电影| 久久亚洲综合av| 国产精品午夜在线| 奇米一区二区三区| 成人av在线观| 91精品国产综合久久久久久久| 欧美激情综合五月色丁香小说| 亚洲国产成人tv| 大胆欧美人体老妇| 精品久久人人做人人爰| 亚洲综合激情小说| 国产91精品一区二区麻豆亚洲| 欧美高清激情brazzers| 综合中文字幕亚洲| 国产精品亚洲一区二区三区妖精| 欧美三区在线观看| 国产精品伦一区| 激情五月婷婷综合网| 欧美日韩成人综合| 亚洲精品写真福利| 成人av免费在线播放| 精品国产一区二区三区四区四| 亚洲福利一区二区| 色综合一区二区| 欧美国产乱子伦| 欧美日韩综合在线免费观看| 国产suv精品一区二区883| 99久久精品免费看| 久久电影国产免费久久电影| 色美美综合视频| 欧美va日韩va| 日韩不卡在线观看日韩不卡视频| 色国产综合视频| 卡一卡二国产精品| 成人国产在线观看| 日韩精品一区二区三区四区视频| 亚洲电影视频在线| 国产91露脸合集magnet | 51精品国自产在线| 欧美tk—视频vk| 激情综合色综合久久| 亚洲国产精品ⅴa在线观看| 久久午夜电影网| 国产午夜精品福利| 亚洲影院久久精品| 久久成人精品无人区| av动漫一区二区| 欧美一级在线观看| 国产精品剧情在线亚洲| 欧美一区二区视频网站| 国产精品久久久久国产精品日日| 成人丝袜高跟foot| 色中色一区二区| 成人国产免费视频| 日韩午夜激情电影| 一卡二卡欧美日韩| 成人网在线播放| 欧美不卡一区二区三区| 一区二区三区欧美日| 国产精品白丝jk白祙喷水网站| 欧美日韩一区三区| 国产精品国产成人国产三级| 蜜桃91丨九色丨蝌蚪91桃色| 国产精品护士白丝一区av| 亚洲婷婷在线视频| 国产一区免费电影| 777a∨成人精品桃花网| 日韩理论片一区二区| 国产一区二区日韩精品| 91麻豆精品国产自产在线观看一区 | 国产精品伦一区二区三级视频| 日韩精彩视频在线观看| 性做久久久久久久免费看| 国产成都精品91一区二区三| 自拍偷拍国产精品| 欧美丰满少妇xxxbbb| 国产精品1区2区| 亚洲乱码国产乱码精品精小说| 欧美久久婷婷综合色| 精品一区二区三区欧美| 中文字幕免费一区| 欧美日本一区二区三区四区| 国产乱码精品一区二区三区忘忧草 | 777奇米成人网| 国产大陆亚洲精品国产| 亚洲四区在线观看| 日韩精品一区二区三区中文不卡 | 日韩视频一区二区| 国产成人日日夜夜| 亚洲成人免费视| 中文字幕av一区二区三区免费看 | 国产日韩欧美在线一区| 欧美性猛交一区二区三区精品| 狠狠v欧美v日韩v亚洲ⅴ| 日韩精品久久久久久| 男人操女人的视频在线观看欧美| 精品国产一区二区三区久久影院| 日本一区二区三区在线不卡| 国产精品三级电影| 蜜臀久久99精品久久久画质超高清| www激情久久| 欧美精品丝袜中出| 蜜臀av一级做a爰片久久| 亚洲精品视频一区二区| 91精品国产91久久久久久一区二区| 五月天亚洲婷婷| 国产精品1区2区| 91精品欧美一区二区三区综合在| 国产精品卡一卡二| 久草精品在线观看| 9l国产精品久久久久麻豆| 午夜免费欧美电影| 最新热久久免费视频| 精品国产凹凸成av人导航| 欧美三日本三级三级在线播放| 成人免费毛片高清视频| 激情久久五月天| 全部av―极品视觉盛宴亚洲| 一卡二卡欧美日韩| 国产欧美视频在线观看| 精品国产露脸精彩对白| 7777精品伊人久久久大香线蕉的 | 激情综合一区二区三区| 欧美国产乱子伦| 在线观看av不卡| 日本不卡一区二区三区| 欧美国产综合一区二区| 欧洲精品在线观看| 经典三级视频一区| 亚洲精品自拍动漫在线| 国产精品一二三四区| 欧美一区二区三区四区五区| 亚洲成av人片在线观看无码| 中文字幕一区二区三区四区| 精品成人私密视频| 欧美mv日韩mv| 日韩欧美不卡在线观看视频| 欧美另类高清zo欧美| 欧美日韩国产免费一区二区| 欧美日韩免费在线视频| 8v天堂国产在线一区二区| 欧美一级在线免费| 精品久久久三级丝袜| 久久久蜜桃精品| 国产精品人妖ts系列视频| 国产精品传媒视频| 亚洲三级视频在线观看| 亚洲制服丝袜av| 日日夜夜一区二区| 久久99精品国产麻豆婷婷洗澡| 九九在线精品视频| 国产成人亚洲综合a∨猫咪| 成人小视频在线| 一本一本久久a久久精品综合麻豆| 色爱区综合激月婷婷| 91麻豆精品91久久久久同性| 久久综合av免费| 中文字幕在线观看不卡| 亚洲自拍偷拍综合| 美女视频黄a大片欧美| 久久精品国产一区二区| 国产成人精品三级麻豆| 欧美影院精品一区| 久久综合国产精品| 亚洲综合色视频| 国产一区二区三区四区五区入口 | 在线观看亚洲精品| 欧美精品一区二区三区蜜桃|