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

        CEG 4136代做、代寫Java/c++設計編程
        CEG 4136代做、代寫Java/c++設計編程

        時間:2024-09-23  來源:合肥網(wǎng)hfw.cc  作者:hfw.cc 我要糾錯



        CEG 4136 Computer Architecture III 
        Fall 2024 
         
        To be submitted September 28, 11:59 p.m. 
         
        Lab1: Optimizing Forest Fire Simulation with CUDA 
          
        1. Introduction 
        In this lab, you will work on a forest fire simulation code that uses a 1000×1000 grid. The fire 
        starts at 100 distinct locations in the forest. The provided code is implemented sequentially. It 
        simulates the propagation of fire, the burning of trees, and their eventual extinction. The grid is 
        displayed using the OpenGL library, where each cell represents a tree or an empty space. 
         
        The objective of this lab is to parallelize the existing code using CUDA C to leverage the power 
        of graphics processing units (GPUs) to make the simulation faster and more efficient. You will 
        identify parts of the code that are most appropriate for optimization, such as the forest update 
        process, and transform them to run in parallel. 
         
        2. Objective 
        The primary objective of this lab is to convert the sequential code into an optimized version using 
        CUDA C to accelerate the simulation. You will learn to: 
        • Identify code sections that can be parallelized. 
        • Use CUDA C to run computations in parallel on a GPU. 
        • Measure the performance gains achieved through parallelization. 
         2 
         
        3. Development Platform 
        Development and optimization of the program will be done on machines equipped with CUDAcapable
         GPUs. The tools to be used include: 
        • CUDA Toolkit (12.6 or later) for compiling CUDA programs. 
        • Visual Studio 2022 for editing and debugging the code. 
        • CUDA Debugger for testing and profiling your CUDA kernels. 
         
        You will use OpenGL for rendering the simulation, and work will be carried out on workstations 
        with NVIDIA GPUs that support CUDA. 
        4. Tasks 
        Step 1: Understand the Starter Code 
        • Analyze the provided code. It is a forest fire simulation where each cell in the grid 
        represents either a tree or an empty space. Fire starts at 100 random locations, spreads to 
        neighboring cells, and burning trees eventually extinguish after a set amount of time. 
        Step 2: Identify Opportunities for Parallelization 
        • Grid updating is a significant part of the code that can be parallelized. Each cell in the grid 
        can be updated independently of the others. 
        • Analyze the updateForest() function, which is responsible for updating the state of 
        burning trees and propagating fire to neighboring cells. This is the section that needs to be 
        optimized using CUDA. 
        Step 3: Implement Parallelization with CUDA C 
        • CUDA Initialization: Allocate memory for the grid (forest) and burn time (burnTime) on 
        the GPU using cudaMalloc(). 
        • CUDA Kernel: Implement a kernel that updates the state of each cell in the forest in 
        parallel. 
        • Parallel Execution: Ensure that each cell in the grid is updated in parallel using multiple 
        threads on the GPU. 
        • Block and Thread Management: Divide the grid into CUDA thread blocks for optimized 
        execution. 
        Step 4: Measure Performance 
        Measure the runtime of the sequential program and compare it to the optimized CUDA version. 
        Use CUDA profiling tools to identify performance gains and any further possible optimizations. 
         3 
         
        5. Deliverables 
        Each team must submit a report containing the following: 
        • An explanation of the parts of the code that were parallelized. 
        • The modified source code with the CUDA implementation. 
        • A performance analysis showing the execution times before and after optimization. 
        • Screenshots of the running program with visual simulation results. 
         
        6. Evaluation Criteria 
        The following criteria will be considered in the evaluation: 
        • Correctness: The program must work correctly after optimization. The simulation should 
        behave the same as the sequential version. 
        • Effective Parallelization: The code should demonstrate proper and effective use of CUDA, 
        with significant parallelization of the appropriate parts of the program. 
        • Performance Improvement: Measurable performance gains should be demonstrated with 
        the CUDA version. The difference in execution times between the sequential and parallel 
        versions must be clearly explained. 
        • Code Quality: The code should be well-structured, commented, and follow good 
        programming practices. 
         
        Note: This lab serves as an introduction to parallelization using CUDA, so it's important to have 
        a solid understanding of the basics of CUDA before you begin coding. 

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





         

        掃一掃在手機打開當前頁
      1. 上一篇:COMP5328代做、代寫Python程序語言
      2. 下一篇:CRICOS編程代做、代寫Java程序設計
      3. 無相關信息
        合肥生活資訊

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

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

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

        主站蜘蛛池模板: 人妻夜夜爽天天爽一区| 国模吧一区二区三区精品视频| 亚洲国产一区二区a毛片| 国产精品一区二区久久| 亚洲国产成人久久综合一区77| 一区二区三区观看免费中文视频在线播放 | 综合无码一区二区三区| 日韩视频免费一区二区三区| 久久久精品人妻一区二区三区| 武侠古典一区二区三区中文| 国产日本一区二区三区| 国产在线视频一区二区三区98| 精品视频一区二区| 久久精品无码一区二区三区不卡| 国产激情з∠视频一区二区| 东京热无码一区二区三区av| 国产精品538一区二区在线| 欧美日韩一区二区成人午夜电影 | 国产日韩精品一区二区在线观看 | 中文无码AV一区二区三区| 精品日韩一区二区| 精品国产一区二区三区久久久狼| 久久无码人妻精品一区二区三区| 高清一区二区在线观看| 在线电影一区二区| 久久一区二区三区精华液使用方法 | 国产激情一区二区三区小说 | 波多野结衣的AV一区二区三区| 亚洲av色香蕉一区二区三区| 天堂国产一区二区三区| 久久精品动漫一区二区三区| 伦理一区二区三区| 国产裸体歌舞一区二区| 果冻传媒董小宛一区二区| 激情内射亚州一区二区三区爱妻| 区三区激情福利综合中文字幕在线一区亚洲视频1 | 国产成人精品一区二区秒拍| 国模私拍一区二区三区| 久久国产精品一区免费下载| 无码国产伦一区二区三区视频| 久久99精品波多结衣一区|