基于AI大文本模型的智慧对话开发设计及C#源码实现,实现智能文本改写与智慧对话

本文主要是介绍基于AI大文本模型的智慧对话开发设计及C#源码实现,实现智能文本改写与智慧对话,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1.AI 大模型发展现状
  • 2.基于AI服务的智慧对话开发
    • 2.1 大模型API选择
    • 2.2 基于C#的聊天界面开发
    • 2.3 星火大模型API接入
    • 2.4 优化开发界面与显示逻辑
  • 3.源码工程Demo及相关软件下载
  • 参考文献

1.AI 大模型发展现状

端午假期几天,关注到国内的AI大模型厂商近乎疯狂地打起了价格战,这边阿里云刚宣布降价97%,那边百度就宣布两款模型全面免费,好不热闹!据不完全统计,国内已有7家大模型企业“参战”,包括字节跳动、阿里云、百度、腾讯云等互联网大厂,智谱AI、深度求索等AI创企,以及垂直赛道头部玩家科大讯飞,纷纷争夺“最便宜”“最高性价比”大模型这块蛋糕。
在这里插入图片描述
▲国内大模型厂商参与价格战情况(智东西制表,统计于2024年5月27日)
总的来看,各大厂商对降价原因的解释无外乎以下几点:技术突破了,推理成本降低了;为开发者兜底,降低大模型的使用门槛;提升产品竞争力,积累客户。但大模型价格战对产业的影响具有两面性,既能够促使产业格局变化和商业模式创新,也为开发者带来机遇,有利于爆款应用的开发和大模型私有化部署。

2.基于AI服务的智慧对话开发

由于工作关系,涉及到相关文字材料的编制,对于某些材料,选用baidu的文心一言或者Aliyun的通义千问对于简单的工作来说可以提升部分效率,但是基于网页端还是存在一些限制,于是计划假期间利用C#语言+VS2015的win界面开发优势,配合大模型API实现快速的文本改写文字降重以及智慧对话的功能

2.1 大模型API选择

选择讯飞星火大模型,其SparkLite免费为开发者开放,且不限tokens和有效期,提供各类开发的Demo源码,对于新手开发的话也比较友好。
在这里插入图片描述

2.2 基于C#的聊天界面开发

聊天界面开发计划基于Panel、RichTextBox、Button、PictureBox组成。其中Button主要负责模拟发送。
在这里插入图片描述

值得说明的是:Panel部分的聊天窗口由设计如下控件组成,且要支持右键菜单的复制和全选的功能,方便获取消息内容。

功能控件
头像PictureBox
昵称Label
发送时间Label
信息详情RichTextBox
右键菜单ContextMenuStrip

实现的效果如下:
在这里插入图片描述

主窗体源码如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;namespace WindowsFormsApplication1
{public partial class Form1 : Form{public Form1(){InitializeComponent();}//新建聊天控件全局变量ChatBubble tsps_chat;private void button1_Click(object sender, EventArgs e){Image touxiang = (WindowsFormsApplication1.Properties.Resources._001);Image touxiang2 = (WindowsFormsApplication1.Properties.Resources._002);//发送tsps_chat.AddMsg(touxiang2,richTextBox1.Text, ChatBubble.MsgPlace.Right, "测试");//模拟接收tsps_chat.AddMsg(touxiang,"你好,我有一个帽衫...",ChatBubble.MsgPlace.Left,"TSPS");}private void Form1_Load(object sender, EventArgs e){panel1.VerticalScroll.Visible = true;panel1.AutoScroll = true;Font ft = new Font("黑体", 12, Font.Style & ~FontStyle.Italic);//创建新的聊天窗口(传入panel和font)tsps_chat = new ChatBubble(panel1, ft);}}}

Panel相关代码如下:

using System;
using System.Collections.Generic;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;namespace WindowsFormsApplication1
{/// <summary>/// 聊天窗口展示类/// </summary>class Class1{}class ChatBubble{/// <summary>/// 生成菜单项/// </summary>/// <param name="txt"></param>/// <param name="img"></param>/// <returns></returns>private ToolStripMenuItem GetMenuItem(string txt, Image img){ToolStripMenuItem menuItem = new ToolStripMenuItem();menuItem.Text = txt;menuItem.Image = img;return menuItem;}/// <summary>/// 菜单项事件响应/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private void toolStripMenuItem_Click(object sender, ToolStripItemClickedEventArgs e){//ToolStripMenuItem menuSend = sender as ToolStripMenuItem;//string selectText = ((RichTextBox)menuSend.).SelectedText;//MessageBox.Show(menu.Text);//获取对应控件的值ContextMenuStrip menu_now = (ContextMenuStrip)sender;RichTextBox tb = ((RichTextBox)(menu_now).SourceControl);if (((ContextMenuStrip)sender).Items[0] == e.ClickedItem)//全选{tb.Focus();//设置先焦点定位到当前活动的RichTextBox,tb.SelectAll();}else if (((ContextMenuStrip)sender).Items[1] == e.ClickedItem)//复制{Clipboard.SetDataObject(tb.SelectedText);}}public ChatBubble(Panel panel, Font font){if (panel.Controls.Count != 0) throw new Exception("指定Panel控件不为空!");ChatPlace = panel;BubbleFont = font;Context_caidan = new ContextMenuStrip();MsgMaxLength = panel.Width - (6 * 4 + 35*2 );    // 其中, 四个6为 图片与(容器以及消息文本框)的距离 ,两个35为两侧图片的大小.//右键菜单编辑Context_caidan.Items.Add("全选");//添加到右键菜单Context_caidan.Items.Add("复制");//添加到右键菜单//绑定消息Context_caidan.ItemClicked += new ToolStripItemClickedEventHandler(toolStripMenuItem_Click);//添加事件//Control.ContextMenuStrip = Context_caidan;}readonly Panel ChatPlace;readonly Font BubbleFont;readonly ContextMenuStrip Context_caidan;//右键复制菜单int NowY = 7;readonly int MsgMaxLength;public enum MsgPlace{Left,Right}              // 气泡创建的位置/// <summary>/// 根据文本内容设置textbox高度等属性/// </summary>/// <param name="txt1"></param>private void SettxtHeight(RichTextBox textBox1,string showString){//属性textBox1.Text = showString;textBox1.Multiline = true;textBox1.WordWrap = true;textBox1.Font = BubbleFont;textBox1.Width = MsgMaxLength;textBox1.BorderStyle = BorderStyle.None;textBox1.ContextMenuStrip = Context_caidan;//为文本框添加右键菜单textBox1.ReadOnly = true;//尺寸参数int txtHeight = 22;//设置单行的行高int MaxLineCount = 20;//设置最大行数Size size = TextRenderer.MeasureText(textBox1.Text, textBox1.Font);int itxtLine = size.Width / textBox1.Width + textBox1.Lines.Count() + 1;if (itxtLine > MaxLineCount) { itxtLine = MaxLineCount; }itxtLine -= 1;textBox1.Height = txtHeight * itxtLine;}public void AddMsg(Image Photo, string Text, MsgPlace Place, string Name){if (ChatPlace.Controls.Count > 4*51) //仅保留近51条消息{ChatPlace.Controls.Clear();NowY = 7;}if (ChatPlace.Controls.Count != 0){NowY = ChatPlace.Controls[ChatPlace.Controls.Count - 2].Location.Y+ ChatPlace.Controls[ChatPlace.Controls.Count - 1].Height + 35;//间隔控制}PictureBox photo = new PictureBox();                // 头像Label nickname = new Label();                       // 昵称Label sendtime = new Label();// Label msg = new Label();RichTextBox msg = new RichTextBox();photo.Size = new Size(35, 35);photo.SizeMode = PictureBoxSizeMode.StretchImage;photo.Image = Photo;nickname.AutoSize = true;nickname.MaximumSize = new Size(0, 0);nickname.Font = BubbleFont;nickname.Text = Name;//获取当前时间string timenow = System.DateTime.Now.ToString("T");sendtime.AutoSize = true;sendtime.MaximumSize = new Size(0, 0);sendtime.Font = BubbleFont;sendtime.Text = timenow;//msg.AutoSize = true;//msg.Font = BubbleFont;//msg.MaximumSize = new Size(MsgMaxLength, 0);// msg.Text = Text;//msg.BorderStyle = BorderStyle.None;SettxtHeight(msg,Text);//自动调整文本框大小ChatPlace.Controls.Add(nickname);ChatPlace.Controls.Add(sendtime);ChatPlace.Controls.Add(photo);ChatPlace.Controls.Add(msg);if (Place == MsgPlace.Left){msg.BackColor = Color.LightGreen;photo.Location = new Point(7, NowY);sendtime.Location = new Point(ChatPlace.Width/2-45, NowY);nickname.Location = new Point(photo.Location.X + photo.Width + 6, NowY);msg.Location = new Point(nickname.Location.X, NowY + nickname.Size.Height);}else{msg.BackColor = Color.LightSkyBlue;photo.Location = new Point(ChatPlace.Width - 7 - 35 - 10, NowY);sendtime.Location = new Point(ChatPlace.Width/2 -45 , NowY);nickname.Location = new Point(photo.Location.X - 7 - nickname.Width - 17, NowY);msg.Location = new Point(photo.Location.X - msg.Width - 10, NowY + nickname.Size.Height);// 这里的减去10是除去滚动条的宽度}//panel滚动条到最下方Point newPoint = new Point(0, ChatPlace.Height - ChatPlace.AutoScrollPosition.Y);ChatPlace.AutoScrollPosition = newPoint;}}        // 简易聊天气泡}

2.3 星火大模型API接入

使用如下C#代码接入讯飞星火大模型API

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net;
using System.Security.Cryptography;
using System.Text;
using System.Threading.Tasks;
using System.Collections;
using Newtonsoft.Json;
using System.Net.WebSockets;
using System.Threading;
using Newtonsoft.Json.Linq;
using System.Text.Json;/*** 星火认知大模型 WebAPI 接口调用示例 接口文档(必看):https://www.xfyun.cn/doc/spark/Web.html* 错误码链接:https://www.xfyun.cn/doc/spark/%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E.html (code返回错误码时必看)* @author iflytek*/
namespace Webiat
{class Program{static ClientWebSocket webSocket0;static CancellationToken cancellation;// 应用APPID(必须为webapi类型应用,并开通星火认知大模型授权)const string x_appid = "XXXXXXXX";// 接口key(webapi类型应用开通星火认知大模型后,控制台--我的应用---星火认知大模型---相应服务的apikey)const string api_secret = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";// 接口密钥(webapi类型应用开通星火认知大模型后,控制台--我的应用---星火认知大模型---相应服务的apisecret)const string api_key = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";static string hostUrl = "https://spark-api.xf-yun.com/v1.1/chat";async public static void Tasker(){string authUrl = GetAuthUrl();string url = authUrl.Replace("http://", "ws://").Replace("https://", "wss://");using (webSocket0 = new ClientWebSocket()){try{await webSocket0.ConnectAsync(new Uri(url), cancellation);JsonRequest request = new JsonRequest();request.header = new Header(){app_id = x_appid,uid = "12345"};request.parameter = new Parameter(){chat = new Chat(){domain = "general",//模型领域,默认为星火通用大模型temperature = 0.5,//温度采样阈值,用于控制生成内容的随机性和多样性,值越大多样性越高;范围(0,1)max_tokens = 1024,//生成内容的最大长度,范围(0,4096)}};request.payload = new Payload(){message = new Message(){text = new List<Content>{new Content() { role = "user", content = "你是谁" },// new Content() { role = "assistant", content = "....." }, // AI的历史回答结果,这里省略了具体内容,可以根据需要添加更多历史对话信息和最新问题的内容。}}};string jsonString = JsonConvert.SerializeObject(request);//连接成功,开始发送数据var frameData2 = System.Text.Encoding.UTF8.GetBytes(jsonString.ToString());webSocket0.SendAsync(new ArraySegment<byte>(frameData2), WebSocketMessageType.Text, true, cancellation);// 接收流式返回结果进行解析byte[] receiveBuffer = new byte[1024];WebSocketReceiveResult result = await webSocket0.ReceiveAsync(new ArraySegment<byte>(receiveBuffer), cancellation);String resp = "";while (!result.CloseStatus.HasValue){if (result.MessageType == WebSocketMessageType.Text){string receivedMessage = Encoding.UTF8.GetString(receiveBuffer, 0, result.Count);//将结果构造为jsonJObject jsonObj = JObject.Parse(receivedMessage);int code = (int)jsonObj["header"]["code"];if(0==code){int status = (int)jsonObj["payload"]["choices"]["status"];JArray textArray = (JArray)jsonObj["payload"]["choices"]["text"];string content = (string)textArray[0]["content"];resp += content;if(status != 2){Console.WriteLine($"已接收到数据: {receivedMessage}");}else{Console.WriteLine($"最后一帧: {receivedMessage}");int totalTokens = (int)jsonObj["payload"]["usage"]["text"]["total_tokens"];Console.WriteLine($"整体返回结果: {resp}");Console.WriteLine($"本次消耗token数: {totalTokens}");break;}}else{Console.WriteLine($"请求报错: {receivedMessage}");}}else if (result.MessageType == WebSocketMessageType.Close){Console.WriteLine("已关闭WebSocket连接");break;}result = await webSocket0.ReceiveAsync(new ArraySegment<byte>(receiveBuffer), cancellation);}}catch (Exception e){Console.WriteLine(e.Message);}}}// 返回code为错误码时,请查询https://www.xfyun.cn/document/error-code解决方案static string GetAuthUrl(){string date = DateTime.UtcNow.ToString("r");Uri uri = new Uri(hostUrl);StringBuilder builder = new StringBuilder("host: ").Append(uri.Host).Append("\n").//Append("date: ").Append(date).Append("\n").//Append("GET ").Append(uri.LocalPath).Append(" HTTP/1.1");string sha = HMACsha256(api_secret, builder.ToString());string authorization = string.Format("api_key=\"{0}\", algorithm=\"{1}\", headers=\"{2}\", signature=\"{3}\"", api_key, "hmac-sha256", "host date request-line", sha);//System.Web.HttpUtility.UrlEncodestring NewUrl = "https://" + uri.Host + uri.LocalPath;string path1 = "authorization" + "=" + Convert.ToBase64String(System.Text.Encoding.UTF8.GetBytes(authorization));date = date.Replace(" ", "%20").Replace(":", "%3A").Replace(",", "%2C");string path2 = "date" + "=" + date;string path3 = "host" + "=" + uri.Host;NewUrl = NewUrl + "?" + path1 + "&" + path2 + "&" + path3;return NewUrl;}public static string HMACsha256(string apiSecretIsKey, string buider){byte[] bytes = System.Text.Encoding.UTF8.GetBytes(apiSecretIsKey);System.Security.Cryptography.HMACSHA256 hMACSHA256 = new System.Security.Cryptography.HMACSHA256(bytes);byte[] date = System.Text.Encoding.UTF8.GetBytes(buider);date = hMACSHA256.ComputeHash(date);hMACSHA256.Clear();return Convert.ToBase64String(date);}static void Main(string[] args){Tasker();Console.ReadLine();}}
}//构造请求体
public class JsonRequest
{public Header header { get; set; }public Parameter parameter { get; set; }public Payload payload { get; set; }
}public class Header
{public string app_id { get; set; }public string uid { get; set; }
}public class Parameter
{public Chat chat { get; set; }
}public class Chat
{public string domain { get; set; }public double temperature { get; set; }public int max_tokens { get; set; }
}public class Payload
{public Message message { get; set; }
}public class Message
{public List<Content> text { get; set; }
}public class Content
{public string role { get; set; }public string content { get; set; }
}

2.4 优化开发界面与显示逻辑

最终调整了实时显示以及界面展示逻辑如下效果
1.获取的数据可以实时显示并自动调整控件大小;
2.可以正常通过按钮进行交互控制;
3.增加进度条用于显示实时状态;
4.支持个人的账号登录。
请添加图片描述
请添加图片描述

3.源码工程Demo及相关软件下载

下载1:讯飞星火大模型C#接入Demo
下载2: C#聊天窗口界面Demo开发
下载3: 打包好的程序,可直接使用: TSPS V32程序,支持讯飞大模型等API接入、论文降重、文本改写、智慧AI对话 或 蓝奏云下载

注:对于上述(3)中打包的程序,若程序打开时显示“Window已保护你的电脑”可以:
1.点击弹窗的“更多信息”
2.点击仍要运行
3.在弹窗中点击“是”即可打开

参考文献

https://www.thepaper.cn/newsDetail_forward_27521760
https://blog.csdn.net/qq_20051033/article/details/104889215?spm=1001.2014.3001.5506

请添加图片描述

这篇关于基于AI大文本模型的智慧对话开发设计及C#源码实现,实现智能文本改写与智慧对话的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050326

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

揭秘未来艺术:AI绘画工具全面介绍

📑前言 随着科技的飞速发展,人工智能(AI)已经逐渐渗透到我们生活的方方面面。在艺术创作领域,AI技术同样展现出了其独特的魅力。今天,我们就来一起探索这个神秘而引人入胜的领域,深入了解AI绘画工具的奥秘及其为艺术创作带来的革命性变革。 一、AI绘画工具的崛起 1.1 颠覆传统绘画模式 在过去,绘画是艺术家们通过手中的画笔,蘸取颜料,在画布上自由挥洒的创造性过程。然而,随着AI绘画工

C# 中变量未赋值能用吗,各种类型的初始值是什么

对于一个局部变量,如果未赋值,是不能使用的 对于属性,未赋值,也能使用有系统默认值,默认值如下: 对于 int 类型,默认值是 0;对于 int? 类型,默认值是 null;对于 bool 类型,默认值是 false;对于 bool? 类型,默认值是 null;对于 string 类型,默认值是 null;对于 string? 类型,哈哈,没有这种写法,会出错;对于 DateTime 类型,默

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

AI儿童绘本创作

之前分享过AI儿童绘画的项目,但是主要问题是角色一致要花费很长的时间! 今天发现了这款,非常奈斯! 只需输入故事主题、风格、模板,软件就会自动创作故事内容,自动生成插画配图,自动根据模板生成成品,测试效果如下图。 变现方式:生成儿童绘本发布到各平台,吸引宝妈群体进私域。  百度网盘 请输入提取码百度网盘为您提供文件的网络备份、同步和分享服务。空间大、速度快、安全

在线装修管理系统的设计

管理员账户功能包括:系统首页,个人中心,管理员管理,装修队管理,用户管理,装修管理,基础数据管理,论坛管理 前台账户功能包括:系统首页,个人中心,公告信息,论坛,装修,装修队 开发系统:Windows 架构模式:B/S JDK版本:Java JDK1.8 开发工具:IDEA(推荐) 数据库版本: mysql5.7 数据库可视化工具: navicat 服务器:SpringBoot自带 ap

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为