当前位置: 首页 > news >正文

C# WPF本地Deepseek部署

在这里插入图片描述
在这里插入图片描述
模型下载地址

using LLama;
using LLama.Common;
using System;
using System.IO;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Input;namespace YF_Talk
{public partial class MainWindow : Window{private LLamaWeights _model;private LLamaContext _context;private InteractiveExecutor _executor;private bool _isInitialized = false;public MainWindow(){InitializeComponent();Loaded += MainWindow_Loaded;}private async void MainWindow_Loaded(object sender, RoutedEventArgs e){await InitializeModelAsync();}private async Task InitializeModelAsync(){try{ChatBox.Text = "正在加载模型,请稍候...\n";// 模型路径 - 确保模型文件放在项目Assets文件夹中var modelPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Assets", "C:\\Users\\Administrator\\Downloads\\DeepSeek-R1-Distill-Qwen-7B-Q4_K_M.gguf");// 模型参数 - 更新为最新APIvar parameters = new ModelParams(modelPath){ContextSize = 2048, // 上下文大小GpuLayerCount = 20, // 使用GPU层数(根据你的GPU调整)};// 加载模型_model = await Task.Run(() => LLamaWeights.LoadFromFile(parameters));_context = await Task.Run(() => new LLamaContext(_model, parameters));_executor = new InteractiveExecutor(_context);_isInitialized = true;ChatBox.Text += "模型加载完成!现在可以开始聊天了。\n\n";InputBox.Focus();}catch (Exception ex){ChatBox.Text += $"初始化失败: {ex.Message}\n";MessageBox.Show($"模型加载失败: {ex.Message}", "错误", MessageBoxButton.OK, MessageBoxImage.Error);}}private async void SendButton_Click(object sender, RoutedEventArgs e){await ProcessInputAsync();}private async void InputBox_KeyDown(object sender, KeyEventArgs e){if (e.Key == Key.Enter){await ProcessInputAsync();}}private async Task ProcessInputAsync(){if (!_isInitialized){ChatBox.Text += "模型尚未加载完成,请稍候...\n";return;}var input = InputBox.Text.Trim();if (string.IsNullOrWhiteSpace(input))return;// 显示用户输入ChatBox.Text += $"你: {input}\n";InputBox.Clear();try{// 准备推理参数 - 更新为最新APIvar inferenceParams = new InferenceParams{//Temperature = 0.6f,AntiPrompts = new[] { "你:", "User:" },MaxTokens = 512,};// 显示AI正在思考ChatBox.Text += "AI: ";// 执行推理await foreach (var text in _executor.InferAsync(input, inferenceParams)){// 逐步显示结果ChatBox.Text += text;ChatBox.ScrollToEnd();}ChatBox.Text += "\n\n";ChatBox.ScrollToEnd();}catch (Exception ex){ChatBox.Text += $"发生错误: {ex.Message}\n";}}protected override void OnClosed(EventArgs e){_context?.Dispose();_model?.Dispose();base.OnClosed(e);}}
}
<Window x:Class="YF_Talk.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:YF_Talk"mc:Ignorable="d"Title="YF Talk - DeepSeek Chat" Height="450" Width="800"><Grid><Grid.RowDefinitions><RowDefinition Height="*"/><RowDefinition Height="Auto"/></Grid.RowDefinitions><ScrollViewer Grid.Row="0" VerticalScrollBarVisibility="Auto"><TextBox x:Name="ChatBox" IsReadOnly="True" TextWrapping="Wrap" VerticalScrollBarVisibility="Auto" FontSize="14" Padding="10"/></ScrollViewer><Grid Grid.Row="1" Margin="5"><Grid.ColumnDefinitions><ColumnDefinition Width="*"/><ColumnDefinition Width="Auto"/></Grid.ColumnDefinitions><TextBox x:Name="InputBox" Grid.Column="0" Margin="0,0,5,0" VerticalContentAlignment="Center" FontSize="14" KeyDown="InputBox_KeyDown"/><Button x:Name="SendButton" Grid.Column="1" Content="发送" Width="80" Click="SendButton_Click"/></Grid></Grid>
</Window>
http://www.dtcms.com/a/329372.html

相关文章:

  • 洛谷 P2607 [ZJOI2008] 骑士-提高+/省选-
  • M4T无人机在外墙脱落监测中的应用:从被动补救到主动预防的技术革新
  • 【代码随想录day 19】 力扣 450.删除二叉搜索树中的节点
  • 从原材料到成品,光模块 PCB 制造工艺全剖析
  • hutool 作为http 客户端工具调用的一点点总结
  • PG靶机 - PayDay
  • pt-online-schema-change 全解析:MySQL 表结构变更的安全之道
  • 编程的几点感悟
  • 【工具】雀语queyu文件批量下载 文档内容复刻导出
  • LeetCode 面试经典 150_数组/字符串_整数转罗马数字(18_12_C++_中等)(模拟)(对各位进行拆解)
  • 地球磁层全球MHD模型中模拟Dst指数的半经验方法
  • 在RHEL 9.X上安装 Docker最新版(28.3.3)
  • 嵌入式|VNC实现开发板远程Debian桌面
  • Spring 源码学习(十)—— DispatcherServlet
  • 专题:2025抖音电商与微短剧行业研究报告|附150+份报告PDF汇总下载
  • 小迪23年-32~40——java简单回顾
  • Hive 创建事务表的方法
  • 机器学习-----DBSCAN算法
  • 进阶向:Python编写自动化邮件发送程序
  • C++多态:理解面向对象的“一个接口,多种实现”
  • [AXI5]AXI协议中awsize和awlen在Vector Atomic地址膨胀中的作用
  • PCIE 配置空间 拓展能力 定义
  • Linux编程 —— framebuffer
  • AJAX学习(2)
  • AI 创作系列(30)海狸 IM:小而全、易二开、快迭代
  • 八爪鱼和影刀的区别和优缺点
  • 【题解】[CQOI2006] 洛谷P4196 凸多边形 /【模板】半平面交
  • AI时代程序员的进化:从代码工人到创意架构师-优雅草卓伊凡引言:AI浪潮下的职业重构
  • Celery在Django中的应用
  • 排序总结---保研机试极限复习