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

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

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

時間:2024-11-16  來源:合肥網(wǎng)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.



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






 

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

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

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

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

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

          欧美电影美腿模特1979在线看 | 国产日韩欧美中文| 亚洲精品视频免费观看| 久久久久久国产精品mv| 欧美日韩免费在线| 日韩午夜免费| 欧美大色视频| 亚洲国产精品视频一区| 久久精品国产久精国产思思| 国产欧美一区二区在线观看| 亚洲视频在线观看视频| 欧美日韩免费观看一区| 亚洲人成亚洲人成在线观看图片| 久热精品在线| 欧美成年人在线观看| 狠狠狠色丁香婷婷综合久久五月| 亚洲综合二区| 国产精品久久久久久影视| 亚洲美女在线看| 欧美日韩大片| 亚洲性人人天天夜夜摸| 欧美性一区二区| 亚洲欧美成人在线| 国产精品影音先锋| 欧美一区二区在线看| 国产亚洲精品成人av久久ww| 久久精品免费播放| 亚洲福利视频免费观看| 欧美1区2区| 99精品国产高清一区二区| 国产精品久久久久9999高清| 午夜在线观看免费一区| 黄网站免费久久| 模特精品在线| 国产精品99久久久久久人 | 亚洲精品乱码| 欧美日韩一卡| 午夜久久美女| 在线色欧美三级视频| 欧美护士18xxxxhd| 国产精品99久久久久久www| 国产精品每日更新在线播放网址| 欧美综合激情网| 亚洲国产精品久久久久| 欧美日韩视频专区在线播放 | 欧美成人自拍视频| 一区二区三区久久| 国产一区观看| 欧美日韩国产综合视频在线观看 | 欧美日韩第一页| 亚洲欧美视频在线| 亚洲国产精彩中文乱码av在线播放| 欧美精品v国产精品v日韩精品| 亚洲综合清纯丝袜自拍| 在线观看91精品国产麻豆| 欧美网站在线| 麻豆av一区二区三区| 亚洲男女自偷自拍| 亚洲精品一区二区三区蜜桃久| 国产精品伊人日日| 欧美日韩三级视频| 久久久久天天天天| 亚洲一区二区日本| 91久久中文| 激情亚洲成人| 国产精品美腿一区在线看| 欧美77777| 久久成人亚洲| 亚洲性xxxx| 9久re热视频在线精品| 在线观看日韩av电影| 国产欧美日韩激情| 欧美天天视频| 欧美激情综合在线| 狂野欧美性猛交xxxx巴西| 亚洲午夜在线| 亚洲日本中文字幕免费在线不卡| 国内成人精品2018免费看| 国产精品久久久久久福利一牛影视 | 麻豆91精品| 午夜精品在线视频| 一区二区冒白浆视频| 亚洲国产综合视频在线观看| 国产日韩亚洲欧美精品| 国产午夜久久| 欧美日韩色综合| 免费在线日韩av| 久久婷婷久久| 久久精品视频免费| 久久精品国产99| 性欧美大战久久久久久久久| 亚洲男人天堂2024| 亚洲男人的天堂在线| 亚洲永久免费精品| 中文欧美字幕免费| 亚洲特级毛片| 亚洲午夜久久久久久久久电影网| 亚洲精品欧美| 日韩亚洲综合在线| 亚洲精品一区二区三区av| 亚洲人成毛片在线播放女女| 亚洲高清视频在线观看| 在线日韩中文| 亚洲狼人综合| 日韩亚洲视频| 亚洲欧美国产视频| 欧美影院在线播放| 久久中文在线| 欧美伦理在线观看| 欧美日韩在线播放三区| 国产精品久久久久久久一区探花| 国产精品久久久久久久9999| 国产免费成人| 一区二区三区在线免费视频| 1024成人网色www| 亚洲裸体视频| 亚洲欧美综合v| 久久琪琪电影院| 欧美日本国产视频| 国产精品欧美久久久久无广告| 国产欧美大片| 亚洲国产精品久久久久秋霞不卡 | 国产欧美日韩不卡| 在线观看成人一级片| 亚洲精品小视频| 午夜精品久久久久久久男人的天堂 | 亚洲欧美视频在线观看视频| 久久国产精品久久久| 欧美99久久| 国产精品久久久久久久久久久久| 国产一区视频在线观看免费| 亚洲国产精品第一区二区| 在线亚洲欧美专区二区| 久久久www成人免费精品| 欧美激情精品久久久| 国产精品一区在线播放| 亚洲国产精品成人综合色在线婷婷| 一区二区三区精品久久久| 久久久999| 欧美日韩一区二区在线| 国内精品国语自产拍在线观看| 日韩午夜激情| 久久精品导航| 国产精品久久二区二区| 亚洲国产精品一区二区久 | 激情综合五月天| 亚洲网站在线播放| 免费短视频成人日韩| 国产欧美精品久久| 99国产精品久久久| 久久人人爽爽爽人久久久| 国产精品av免费在线观看 | 亚洲国产精品久久人人爱蜜臀| 亚洲与欧洲av电影| 欧美精品九九| 一区二区三区在线观看欧美| 亚洲欧美国产精品va在线观看| 欧美好吊妞视频| 亚洲高清av| 久久久久久久999精品视频| 国产精品日韩精品| 一区二区三区免费看| 欧美不卡在线视频| 在线播放日韩欧美| 欧美在线观看一区二区三区| 国产情侣一区| 中国成人黄色视屏| 欧美乱妇高清无乱码| 一区二区亚洲欧洲国产日韩| 亚洲欧美一区二区激情| 欧美日韩精品二区第二页| 亚洲国产日韩欧美在线99 | 欧美中在线观看| 国产精品白丝黑袜喷水久久久| 亚洲欧洲日本专区| 蜜桃av久久久亚洲精品| 国内偷自视频区视频综合| 欧美专区亚洲专区| 国产一区在线看| 欧美自拍偷拍| 国产一区二区中文| 久久久国产亚洲精品| 亚洲一区二区三区视频| 欧美高清一区| 亚洲精品在线观| 国产一区二区日韩| 久久黄色级2电影| 亚洲激情校园春色| 欧美日韩一区视频| 亚洲欧美国产高清| 国产精品夜夜夜| 欧美成人一区在线| 一本色道久久综合亚洲精品小说| 欧美福利在线观看| 夜夜精品视频| 亚洲精选在线观看| 欧美一区二区三区啪啪| 欧美sm极限捆绑bd| 亚洲毛片一区| 国产精品国产亚洲精品看不卡15 |