matlab调用ChatGPT保姆级教程,文末有赠书彩蛋 您所在的位置:网站首页 matlab软件破解版 matlab调用ChatGPT保姆级教程,文末有赠书彩蛋

matlab调用ChatGPT保姆级教程,文末有赠书彩蛋

2023-03-11 20:04| 来源: 网络整理| 查看: 265

4a183635a0332d76ef87b9baa544bef0.png

之前用matlab的appdesigner写了一个调用ChatGPT API的小工具,并作了上面的小视频分享在各个视频平台上,之后用不少伙伴找咱要这个代码。之前的分享的时候能调用的最高级模型也就是text-davinci-003,现在都已经更新到了gpt-3.5-turbo和gpt-3.5-turbo-0301。据说这个模型和现在大家用的那个官方网页版的效果非常接近,当然,咱是没有亲测过了。

新模型新气象,天下不会掉馅饼,调用新模型并不免费,而是按0.002美元/1000 tokens计费。

2707487b98cec01a3c4e4e4a7ca9bbe3.png

为了方便大家体验,新用户会有18美元的体验金,这个体验金是有效期的,在有效期之内才能。

31927c57e90c53f97339afe7a7c80725.jpeg

想要调用gpt-3.5-turbo模型,首先就得要有一个可用的openapi账号并创建一个api-keys供调用时验证。

下面通过实例来看看如何在matlab中调用chatgpt的api,问它如何用matlab在区间x~[-pi, pi],y~[-pi, pi]上绘制z=sin(x)*cos(y)的三维图:

问题如下:

how to make a figure and plot z=sin(x)*cos(y) for x=-pi to + pi and y = -pi to +pi using matlab?

导入HTTP包:

import matlab.net.* import matlab.net.http.*

定义消息内容:

umesges = "how to make a figure and plot z=sin(x)*cos(y) for x=-pi to + pi and y = -pi to +pi using matlab"; mesges = [struct('role',"system", ... 'content',"You are a helpful assistant."); struct('role',"user",'content',umesges)];

定义服务器链接和api-keys:

apiurl = "https://api.openai.com/v1/chat/completions"; apikey = "此处为你自己的api-keys";

定义请求头和请求方法:

% 定义请求消息 querymsg = struct('model',"gpt-3.5-turbo",... 'messages',mesges, ... 'max_tokens',1000,... 'temperature',0.75); % 请求头 headers = HeaderField('Content-Type', 'application/json',... 'Authorization', "Bearer " + apikey); % 请求消息 request  = RequestMessage('post',headers,querymsg);

向服务器发送请求:

response = send(request, URI(apiurl));

处理反馈信息:

if response.StatusCode == "OK" responseText = response.Body.Data.choices(1).message; responseText = string(responseText.content); responseText = strtrim(responseText); disp(responseText); else responseText = "Error "; responseText = responseText + response.StatusCode + newline; responseText = responseText + response.StatusLine.ReasonPhrase; end

反馈结果如下:

Sure, you can use the following code to create a figure and plot the function z=sin(x)*cos(y) in MATLAB: ``` % Define the range of x and y values x = linspace(-pi, pi, 100); y = linspace(-pi, pi, 100); % Create a grid of x and y values [X, Y] = meshgrid(x, y); % Compute the function z=sin(x)*cos(y) Z = sin(X).*cos(Y); % Create a new figure figure(); % Plot the function using surf function surf(X, Y, Z); % Set the color map to 'jet' colormap('jet'); % Add a color bar colorbar(); % Add labels for the axes and title xlabel('x'); ylabel('y'); zlabel('z'); title('z = sin(x)*cos(y)'); ``` This code will create a 3D plot of the function z=sin(x)*cos(y) for x=-pi to + pi and y = -pi to +pi, with x, y, and z axes labeled and a color bar indicating the values of z. You can customize the plot further by adjusting the grid size, color map, and other plot properties as needed.

这样就完成了整个对ChatGPT API的调用过程,通过稍加改进完善就可以做成一个即时的ChatGPT聊天机器人。这里需要特别感谢Hans Scharler在matlab的官方问答论坛中首次给出了在matlab调用ChatGPT的解决方案。Duncan Carlsmith基于Hans Scharler的答案在File Exchange中分享了几个使用ChatGPT生成m文件的小工具。Toshiakit基于基于Hans Scharler的答案开发了一个专门用于调用ChatGPT API的chatGPT类。以上提到的内容都可在参考资料中找到,想进一步研究的伙伴可通过参考资料深入学习。

~~~文末彩蛋~~~

上次分享赠书活动之后,小伙伴意犹未尽,有的本来完成了分享,可惜错过了领取时间,经小编与出版社朋友沟通之后,人家决定再给咱公众号的铁粉送一波福利。

这次为伙伴们准备5本由清华大学出版社出版的《深入浅出R语言数据分析》正版图书。此书有理论,有应用,有技巧;从数据读取、网络爬虫,到数据分析方法,应有尽有;介绍了常用的12种数据分析方法,针对每种方法,都给出了相应代码,拿来就用。此外,为方便读者学习,还免费提供配套学习视频和源程序下载。

c12858108e6642cce73e59d45177e832.png

不想参与活动但又需要此书的伙伴可通过上方链接直接在京东购买!

活动参与方式:本次采用3+2的方式,即三本在科研学术交流群通过抢红包的方式领取,两本通过在本推文下方留言获点赞的方式。

方式一:在巴山学长公众号后台回复“原创”加入科研学术交流群,届时将在群中抽出三个获赠资格,已在群中的伙伴直接等待开奖即可。

方式二:直接在本推文下方留言,留言获点赞数最高的前两名获得赠书资格。若出现最高点赞数且人数超过2,则以先留言者优先。

活动结束时间:2023年3月10日 20:00

领取方式:只要参与分享本推文的伙伴,务必在公众号后台回复QQ,加入专属交流群,并即时关注群中最新动态。届时将在该群中公布获赠资格以及后续的联系之用。资格的最迟领取日期为2023年3月11日,超过此日期未领取则视为自动放弃资格,咱将自行分配资格给其他需要的伙伴。

祝伙伴们生活、工作愉快,有缘再见!!!

参考资料:

[1] matlabcentral/answers/1894530-connecting-to-chatgpt-using-api

[2] github.com/toshiakit/chatgpt_matlab

[3] matlabcentral/fileexchange/124080-chatgpt-generated-matlab-program

[4] github.com/OpsConfig/OpenAI_Lab/blob/main/chatgpt/ChatGPT%20Demo.ipynb

封面图片:由 Ruby Chen 在openai.com/blog/chatgpt上发布

如需转载,请在公众号中回复“转载”获取授权,如未经授权擅自搬运抄袭的,本公众号将保留一切追责权利!



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有