拉力测试cuda pytorch 把 4070显卡拉满

复制代码
import torch
import time


def stress_test_gpu(matrix_size=16384, duration=300):
    """
    对GPU进行压力测试,通过持续的矩阵乘法来最大化GPU利用率

    参数:
        matrix_size: 矩阵维度大小,增大可提高计算复杂度
        duration: 测试持续时间(秒)
    """
    # 检查CUDA是否可用
    if not torch.cuda.is_available():
        print("CUDA不可用,无法进行GPU压力测试!")
        return

    # 获取GPU设备
    device = torch.device("cuda:0")
    print(f"使用GPU: {torch.cuda.get_device_name(device)}")

    # 创建大型矩阵并移到GPU
    print(f"正在创建 {matrix_size}x{matrix_size} 的矩阵...")
    a = torch.randn(matrix_size, matrix_size, device=device)
    b = torch.randn(matrix_size, matrix_size, device=device)

    # 预热GPU
    print("预热GPU中...")
    for _ in range(3):
        c = torch.matmul(a, b)
    torch.cuda.synchronize()

    # 开始压力测试
    print(f"开始GPU压力测试,持续 {duration} 秒...")
    start_time = time.time()
    iterations = 0

    try:
        while time.time() - start_time < duration:
            # 执行矩阵乘法(计算密集型操作)
            c = torch.matmul(a, b)

            # 同步设备以确保计算完成
            torch.cuda.synchronize()
            iterations += 1

            # 每10秒打印一次进度
            if iterations % 10 == 0:
                elapsed = time.time() - start_time
                print(f"已运行 {elapsed:.1f}s / {duration}s,迭代次数: {iterations}")

    except KeyboardInterrupt:
        print("测试被用户中断")

    finally:
        # 清理资源
        del a, b, c
        torch.cuda.empty_cache()

        # 计算性能指标
        elapsed = time.time() - start_time
        print(f"\n压力测试完成!")
        print(f"总运行时间: {elapsed:.2f} 秒")
        print(f"总迭代次数: {iterations}")
        print(f"平均每秒迭代: {iterations / elapsed:.2f}")


if __name__ == "__main__":
    # 可调整矩阵大小以平衡性能和显存使用
    # 16384x16384 矩阵约占用2GB显存 (4070有12GB显存)
    stress_test_gpu(matrix_size=16384, duration=300)
相关推荐
政安晨7 分钟前
政安晨【零基础玩转开源AI项目】- AutoGPT:全球首个自主AI Agent从入门到实战(致敬OpenClaw的小回顾)
人工智能·ai·autogpt·全球首个agent框架·致敬openclaw之作·参考价值·ai开源agent框架
Shawn_Shawn5 小时前
mcp学习笔记(一)-mcp核心概念梳理
人工智能·llm·mcp
冷雨夜中漫步6 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
33三 三like7 小时前
《基于知识图谱和智能推荐的养老志愿服务系统》开发日志
人工智能·知识图谱
芝士爱知识a7 小时前
【工具推荐】2026公考App横向评测:粉笔、华图与智蛙面试App功能对比
人工智能·软件推荐·ai教育·结构化面试·公考app·智蛙面试app·公考上岸
郝学胜-神的一滴7 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再7 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
Forrit7 小时前
ptyorch安装
pytorch
腾讯云开发者8 小时前
港科大熊辉|AI时代的职场新坐标——为什么你应该去“数据稀疏“的地方?
人工智能
工程师老罗8 小时前
YoloV1数据集格式转换,VOC XML→YOLOv1张量
xml·人工智能·yolo