[Rust-Burn][01]初体验

使用Rust Burn进行深度学习


最近大模型和以文生图很火,看到了一些Rust在高性能推理方面的应用价值,其次也看到了Rust在量化方向的潜力,准备探索一下副业。

安装

使用cargo新建项目,然后添加burn库

cargo new test_burn
cargo add burn --features wgpu,tch,cuda,dataset,train,candle

burn-tch是封装了c++版本的torch库,需要去torch官网手动下载c++版本的压缩包。

后端

burn支持多种后端进行实际的计算,如webgpu、torch、candle等,如果追求跨平台可以考虑webgpu,如果追求性能,首选torch,candle比较新,不太好评价。

测试

这里测试webgpu、torch、candle。

use burn::backend::{libtorch, LibTorch};
use burn::backend::{wgpu, Wgpu};
use burn::backend::{candle, Candle};
use burn::tensor::Tensor;


fn main() {
    {
        type MyBackend = Wgpu<wgpu::Vulkan, f32, i32>;
        let device = wgpu::WgpuDevice::DiscreteGpu(0);
        println!("{:#?}", device);

        let tensor_1 = Tensor::<MyBackend, 2>::from_data([[2., 3.], [4., 5.]], &device);
        let tensor_2 = Tensor::<MyBackend, 2>::ones_like(&tensor_1);

        println!("{}", tensor_1 + tensor_2);
    }
    {
        type MyBackend = Candle;
        let device = candle::CandleDevice::Cuda(0);
        println!("{:#?}", device);

        let tensor_1 = Tensor::<MyBackend, 2>::from_data([[2., 3.], [4., 5.]], &device);
        let tensor_2 = Tensor::<MyBackend, 2>::ones_like(&tensor_1);

        println!("{}", tensor_1 + tensor_2);
    }
    {
        type MyBackend = LibTorch;
        let device = libtorch::LibTorchDevice::Cuda(0);
        println!("{:#?}", device);
        let tensor_1 = Tensor::<MyBackend, 2>::from_data([[2., 3.], [4., 5.]], &device);
        let tensor_2 = Tensor::<MyBackend, 2>::ones_like(&tensor_1);

        println!("{}", tensor_1 + tensor_2);
    }
}

运行时需要设置torch相关的环境变量,参考tch-rs

  • 7
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要配置rust-analyzer的代码提示,你可以按照以下步骤进行操作: 1. 确保已经在你的项目中安装了rust-analyzer插件。你可以在VSCode的插件市场中搜索并安装"rust-analyzer"插件。 2. 打开VSCode的设置(可以通过菜单栏的"文件" -> "首选项" -> "设置"或者使用快捷键Ctrl + ,打开设置)。 3. 在设置页面的搜索框中输入"rust-analyzer",找到相关的设置选项。 4. 根据你的需求,配置下列常用的代码提示相关的设置: - "rust-analyzer.enable": 设置为true以启用rust-analyzer插件。 - "rust-analyzer.completion.enable": 设置为true以启用代码补全功能。 - "rust-analyzer.completion.addCallArgumentSnippets": 设置为true以自动添加函数调用时的参数提示。 - "rust-analyzer.completion.addCallParenthesis": 设置为true以自动添加函数调用时的括号。 - "rust-analyzer.completion.postfix.enable": 设置为true以启用后缀代码补全功能,例如`.if`、`.let`等。 - "rust-analyzer.hover.enable": 设置为true以启用悬停提示功能。 - "rust-analyzer.inlayHints.enable": 设置为true以启用内联提示功能。 5. 根据你的需求,可以进一步自定义配置rust-analyzer的代码提示行为。你可以在设置中找到更多相关的选项,并根据注释进行配置。 6. 保存设置,并重启VSCode使更改生效。 通过以上步骤,你可以根据自己的喜好和需求来配置rust-analyzer的代码提示功能。请注意,具体的配置选项可能会因rust-analyzer插件版本的不同而有所差异,请参考插件的官方文档或参考其它资源获取更多定制化的配置信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值