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

用AI助手写程序

用AI帮助写程序究竟靠不靠谱,下面来测试一下:

在文心一言中输入:写一个C++ Windows API串口通信程序。结果如下:

#include <windows.h>  
#include <iostream>  // 串口配置  
void ConfigureCommPort(HANDLE hComm) {  DCB dcbSerialParams = {0};  dcbSerialParams.DCBlength = sizeof(dcbSerialParams);  if (!GetCommState(hComm, &dcbSerialParams)) {  std::cerr << "Error getting state" << std::endl;  return;  }  dcbSerialParams.BaudRate = CBR_9600;  dcbSerialParams.ByteSize = 8;  dcbSerialParams.StopBits = ONESTOPBIT;  dcbSerialParams.Parity = NOPARITY;  if (!SetCommState(hComm, &dcbSerialParams)) {  std::cerr << "Error setting serial port state" << std::endl;  return;  }  COMMTIMEOUTS timeouts = {0};  timeouts.ReadIntervalTimeout = 50;  timeouts.ReadTotalTimeoutConstant = 50;  timeouts.ReadTotalTimeoutMultiplier = 10;  timeouts.WriteTotalTimeoutConstant = 50;  timeouts.WriteTotalTimeoutMultiplier = 10;  if (!SetCommTimeouts(hComm, &timeouts)) {  std::cerr << "Error setting timeouts" << std::endl;  return;  }  
}  // 发送数据  
bool WriteCommPort(HANDLE hComm, const char* data, DWORD length) {  DWORD bytes_written;  if (!WriteFile(hComm, data, length, &bytes_written, NULL)) {  std::cerr << "Error writing to serial port" << std::endl;  return false;  }  return true;  
}  // 接收数据  
bool ReadCommPort(HANDLE hComm, char* buffer, DWORD buffer_size, LPDWORD bytes_read) {  if (!ReadFile(hComm, buffer, buffer_size, bytes_read, NULL)) {  std::cerr << "Error reading from serial port" << std::endl;  return false;  }  return true;  
}  int main() {  HANDLE hComm;  hComm = CreateFile("COM3", GENERIC_READ | GENERIC_WRITE, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);  if (hComm == INVALID_HANDLE_VALUE) {  std::cerr << "Error opening serial port" << std::endl;  return 1;  }  ConfigureCommPort(hComm);  const char* send_data = "Hello, Serial Port!";  if (!WriteCommPort(hComm, send_data, strlen(send_data))) {  CloseHandle(hComm);  return 1;  }  char buffer[128];  DWORD bytes_read;  if (!ReadCommPort(hComm, buffer, sizeof(buffer), &bytes_read)) {  CloseHandle(hComm);  return 1;  }  buffer[bytes_read] = '\0'; // Null-terminate the string  std::cout << "Received: " << buffer << std::endl;  CloseHandle(hComm);  return 0;  
}

 在钉钉AI助手中同样输入:写一个C++ Windows API串口通信程序,钉钉AI助手结果如下:

        编写一个使用C++和Windows API进行串口通信的程序,涉及到使用Windows的串行通信API函数。以下是一个基础示例程序的概要和关键步骤,这应当能指引你开始编码:1. 包含必要的头文件:首先,在你的C++源文件中包含Windows API中关于串口通信的头文件。#include <windows.h>
#include <stdio.h>
cpp2. 定义串口句柄和配置结构体:你需要一个HANDLE变量来存储串口句柄,并设置DCB结构体来配置串口。HANDLE hSerial;
DCB dcbSerialParams;
cpp3. 打开串口:使用CreateFile函数以指定的参数打开串口。hSerial = CreateFile("COM1", // 串口号,根据实际情况修改
GENERIC_READ | GENERIC_WRITE,
0,
NULL,
OPEN_EXISTING,
0,
NULL);
if (hSerial == INVALID_HANDLE_VALUE) {
// 处理错误
}
cpp4. 配置串口参数:使用GetCommState获取当前配置,然后修改DCB结构体的成员以设置所需的波特率、数据位、停止位等,最后用SetCommState应用配置。if (!GetCommState(hSerial, &dcbSerialParams)) {
// 处理错误
}
// 配置DCB结构体...
dcbSerialParams.BaudRate = CBR_9600; // 波特率
dcbSerialParams.ByteSize = 8; // 数据位数
dcbSerialParams.StopBits = ONESTOPBIT; // 停止位
dcbSerialParams.Parity = NOPARITY; // 无校验位

if (!SetCommState(hSerial, &dcbSerialParams)) {
// 处理错误
}
cpp5. 读写操作:使用ReadFile和WriteFile函数进行数据的读写。DWORD dwBytesRead, dwBytesWritten;
char buffer[100];

// 写数据
if (!WriteFile(hSerial, "Hello COM1", sizeof("Hello COM1") - 1, &dwBytesWritten, NULL)) {
// 处理错误
}

// 读数据
if (!ReadFile(hSerial, buffer, sizeof(buffer), &dwBytesRead, NULL)) {
// 处理错误
}
buffer[dwBytesRead] = '\0'; // 添加字符串结束符
printf("Received: %s\n", buffer);
cpp6. 关闭串口:使用CloseHandle关闭串口句柄。CloseHandle(hSerial);
cpp以上是一个基本的C++ Windows API串口通信程序的框架。请根据实际需求调整串口号、波特率等参数,并添加适当的错误处理机制。由于编写和调试实际代码超出了我的直接服务范围,我无法直接为你编写或测试代码。但根据上述指南,你应该能够着手实现你的串口通信程序。

   2  在文心一言中输入:写一个OpenCV Mat对象转BitMap对象程序。结果如下:

import org.opencv.android.Utils;  
import org.opencv.core.Mat;  import android.graphics.Bitmap;  public Bitmap matToBitmap(Mat src) {  // 创建一个空的Bitmap对象  Bitmap bmp = null;  if (src != null && !src.empty()) {  // 将Mat对象转换为Bitmap,这里注意OpenCV的Mat图像是BGR格式,而Android Bitmap是ARGB_8888格式  // 因此,我们不需要进行颜色空间转换(如果Mat已经是RGB,则需要)  // 第二个参数是是否需要对图像进行缩放,这里传入false表示不进行缩放  // 第四个参数是要求的目标Bitmap的像素类型,这里使用ARGB_8888  bmp = Bitmap.createBitmap(src.cols(), src.rows(), Bitmap.Config.ARGB_8888);  // 调用Utils类的matToBitmap方法完成转换  Utils.matToBitmap(src, bmp);  }  return bmp;  
}

   再输入:写一个OpenCV C++ Mat对象转BitMap对象程序,结果如下:

#include <opencv2/opencv.hpp>  
#include <vector>  // 假设这个函数用于将Mat转换为字节数组(模拟Bitmap数据)  
std::vector<unsigned char> MatToByteArray(const cv::Mat& mat) {  if (mat.empty()) {  throw std::runtime_error("Mat is empty!");  }  // OpenCV的Mat是BGR格式的,我们需要转换为ARGB格式(Android Bitmap格式)  // 注意:这里我们简单地忽略了Alpha通道,将其设置为255(不透明)  std::vector<unsigned char> bitmapData;  bitmapData.resize(mat.rows * mat.cols * 4); // ARGB,所以每个像素4个字节  for (int y = 0; y < mat.rows; ++y) {  for (int x = 0; x < mat.cols; ++x) {  cv::Vec3b bgr = mat.at<cv::Vec3b>(y, x); // 获取BGR像素值  // 设置ARGB值,注意顺序和忽略Alpha(设为255)  bitmapData[(y * mat.cols + x) * 4 + 0] = 255; // A  bitmapData[(y * mat.cols + x) * 4 + 1] = bgr[2]; // R  bitmapData[(y * mat.cols + x) * 4 + 2] = bgr[1]; // G  bitmapData[(y * mat.cols + x) * 4 + 3] = bgr[0]; // B  }  }  return bitmapData;  
}  // 注意:这个函数没有直接创建Android Bitmap对象,而是创建了一个可以在C++中使用的字节数组  
// 你需要通过JNI将这个字节数组传递给Java层,并在那里创建Bitmap对象

 在钉钉AI助手中输入:写一个OpenCV Mat对象转BitMap对象程序,结果如下:

        要将OpenCV的Mat对象转换为Windows GDI的Bitmap对象,你可以按照以下步骤编写程序:1. 包含必要的头文件: 确保你的程序包含了OpenCV和Windows GDI相关的头文件。#include <opencv2/opencv.hpp>
#include <windows.h>
cpp2. 定义转换函数: 创建一个函数,该函数接受一个OpenCV的cv::Mat对象,并返回一个指向HBITMAP(位图句柄)的指针。这个函数将执行实际的转换操作。HBITMAP MatToBitmap(const cv::Mat& matImage)
{
if (matImage.empty())
return NULL;

// 获取图像的宽度和高度
int width = matImage.cols;
int height = matImage.rows;

// 创建兼容DC(设备上下文)
HDC hdc = GetDC(NULL);
HDC compatibleDC = CreateCompatibleDC(hdc);

// 创建Bitmap信息头
BITMAPINFO bmi;
memset(&bmi, 0, sizeof(bmi));
bmi.bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
bmi.bmiHeader.biWidth = width;
bmi.bmiHeader.biHeight = -height; // 高度为负表示顶部向下增长
bmi.bmiHeader.biPlanes = 1;
bmi.bmiHeader.biBitCount = 32;
bmi.bmiHeader.biCompression = BI_RGB;

// 创建DIB(设备无关位图)
void* pBits;
HBITMAP hBitmap = CreateDIBSection(compatibleDC, &bmi, DIB_RGB_COLORS, &pBits, NULL, 0);

// 将Mat数据复制到Bitmap
memcpy(pBits, matImage.data, matImage.total() * matImage.elemSize());

// 清理
DeleteDC(compatibleDC);
ReleaseDC(NULL, hdc);

return hBitmap;
}
cpp3. 使用转换函数: 现在,你可以使用上面定义的MatToBitmap函数将任何OpenCV的Mat对象转换为Bitmap对象。例如:int main()
{
cv::Mat img = cv::imread("image_path.jpg"); // 读取图像
if (img.empty())
{
std::cout << "Could not open or find the image" << std::endl;
return -1;
}

HBITMAP hBitmap = MatToBitmap(img);
if (hBitmap != NULL)
{
// 使用hBitmap进行GDI操作,如显示在窗口等
// ...

// 不要忘记释放Bitmap资源
DeleteObject(hBitmap);
}

return 0;
}
cpp以上代码演示了如何将OpenCV的Mat对象转换为Windows Bitmap对象,并提供了基本的错误检查和资源管理。请根据你的具体应用场景调整和使用这段代码。由于我已经提供了完整的解决方案,接下来的操作为:内容由AI生成保存代码到文档如何在C++中显示Bitmap?这段代码有哪些优化空间?

      二者比较,文心一言像个老手认真在写程序(先不说这个程序怎么样),钉钉AI助手感觉有点像在写教程。不管怎么样,对写程序确实都有些帮助,是很好的工具。想依靠它们来独立完成一个功能齐全的复杂程序,目前还不太现实。

http://www.lryc.cn/news/416708.html

相关文章:

  • 动手学深度学习7.2 使用块的网络(VGG)-笔记练习(PyTorch)
  • SolidityFoundry ERC4626
  • 大模型时代的操作系统:融合 Rust 和大模型,打造 AI 操作系统
  • 【ML】为什么要做batch normlization,怎么做batch normlization
  • 【C++指南】命名空间
  • RocketMQ Dashboard安装
  • 前端web开发HTML+CSS3+移动web(0基础,超详细)——第3天
  • 认识MySQL
  • 尚品汇-创建ES索引库(二十七)
  • 设计模式-六大原则
  • MyBatis搭建和增删改查
  • 【一图学技术】6.反向代理 vs API网关 vs 负载均衡的原理和使用场景
  • python爬虫番外篇 | Reuqests库高级用法(1)
  • 【链表OJ】常见面试题 3
  • Linux学习笔记9(Linux包管理)
  • 论文阅读《Geometric deep learning of RNA structure》
  • 宏集方案 | 传统建筑智能化改造,迈向物联新时代
  • 如果服务器更改Web端口会减少被攻击的风险吗?
  • vim列编辑模式
  • 如何实现pxe安装部署
  • 机器学习常见模型
  • 【python案例】基于Python 爬虫的房地产数据可视化分析设计与实现
  • 如何在Python中诊断和解决内存溢出问题
  • 什么是爬虫软件?这两个爬虫神器你必须要试试
  • 记录|MVS和VM软件使用记录
  • 算法通关:014_1:用栈实现队列
  • 【C#】Random
  • MongoDB简介及其在Java中的应用
  • JSON-LD上下文将属性映射到RDF IRIs示例
  • Spring的监听机制详解