前言
ChatGPT最近挺火的,据说还能写程序,感到有些惊讶。于是在使用ChatGPT有一周左右后,分享一下用它写程序的效果如何。
1、对于矩阵,把减法操作转换加法?
data:image/s3,"s3://crabby-images/50816/50816331273e58fdeb9ea403bfc73a6cedd22e22" alt=""
data:image/s3,"s3://crabby-images/7d227/7d2271214166aa2057b18cbf05969e777e26e0e2" alt=""
感觉不错的,能清晰介绍原理,然后写示例程序,还给出了示例的运行结果。
2、写一个程序,矩阵除法转换为矩阵除法
data:image/s3,"s3://crabby-images/5348d/5348dd2293bfb83622d9fa65f7449bb62d7f79b1" alt=""
上面是一个简答的例子,要求程序详细一些
data:image/s3,"s3://crabby-images/2ef74/2ef74f088828ac562d07e906adf782ec3659daa7" alt=""
data:image/s3,"s3://crabby-images/c2f54/c2f5456736bc93278ff2c0958dcb2526e62be365" alt=""
当要求程序详细一些时,它会写得很详细些,这个不错的;
但是在解释原理时,公式显示乱码了,这点有待完善。
3、写一个程序,pytorch模型转onnx
data:image/s3,"s3://crabby-images/4a8ff/4a8ff1ff1fa2601cd6675cdfa6c83bf26e5a6b56" alt=""
data:image/s3,"s3://crabby-images/9121c/9121ce836c99261f7c740d5460671051abcf3412" alt=""
data:image/s3,"s3://crabby-images/45cc2/45cc2efaa3107ad21e9e60f8e78394c84334b806" alt=""
data:image/s3,"s3://crabby-images/611b4/611b440f6e91e2b22237900916d9ec6cc153e999" alt=""
data:image/s3,"s3://crabby-images/41141/41141a7056b084602bdd9272d8ec9e2e3996e68c" alt=""
对于特定领域的知识(ONNX模型转换),它也是知道的,能根据需求,写出示例程序。
4、写一个程序,遍历彩色图片
data:image/s3,"s3://crabby-images/a9559/a955981c8057c89e53f4a31316371c0896624fab" alt=""
data:image/s3,"s3://crabby-images/ad09b/ad09b19a9758e85b9c58e0cf82e5338ecd0bd0c9" alt=""
data:image/s3,"s3://crabby-images/21fe9/21fe9a1ef1feba8c64cd7324f4dbef2581dcc84f" alt=""
data:image/s3,"s3://crabby-images/659d1/659d1a12f43bc8d8f3249dbf1277dd1a527d9e9a" alt=""
data:image/s3,"s3://crabby-images/c627a/c627a45e9247cdc425abce01db9ca4deb97f5c55" alt=""
5、写一个程序,遍历三维数组
data:image/s3,"s3://crabby-images/9358e/9358e9bf19df435d2279857e04025c279a071a25" alt=""
data:image/s3,"s3://crabby-images/04fbf/04fbf26884358e74196421c5ab200a8d710fa481" alt=""
data:image/s3,"s3://crabby-images/fb7ab/fb7abadfada0c786d290e1dd984dfd046b3c3272" alt=""
data:image/s3,"s3://crabby-images/b20d0/b20d0b2f46dcb2409058ee7a6addc63b6166d308" alt=""
data:image/s3,"s3://crabby-images/9b263/9b2637815ea5203d7d18a271054a3e4e3aeda71c" alt=""
但是呢,上面的程序会报错:
ValueError: index 10016 is out of bounds for array with size 10000
data:image/s3,"s3://crabby-images/a931a/a931a83c9abeeccef1553a537382857273e07008" alt=""
6、写个程序,实现彩色图片灰度化,灰度值是每个通道的平均值
data:image/s3,"s3://crabby-images/06bfa/06bfada3d1c03aa6cdd0dabd9146966a0b244ca7" alt=""
data:image/s3,"s3://crabby-images/909cf/909cf852ce6b2ca09b386156e512fb4f0c91a7a4" alt=""
7、使用opencv检测图片的轮廓,拟合直线
data:image/s3,"s3://crabby-images/395e6/395e69b6e355c8343c88d8310b31a55ea9a24612" alt=""
-
import cv2
-
import numpy
as np
-
-
# 读取图像并转换为灰度图像
-
img = cv2.imread(
'image.jpg')
-
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
-
-
# 对图像进行二值化处理
-
ret, thresh = cv2.threshold(gray,
127,
255, cv2.THRESH_BINARY)
-
-
# 找到图像中的轮廓
-
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
-
-
# 对每个轮廓拟合多条直线
-
for cnt
in contours:
-
# 近似轮廓
-
epsilon =
0.01 * cv2.arcLength(cnt,
True)
-
approx = cv2.approxPolyDP(cnt, epsilon,
True)
-
-
# 计算轮廓的凸包
-
hull = cv2.convexHull(approx, returnPoints=
False)
-
-
# 如果轮廓点的数量不足 5 个,则不做拟合
-
if
len(approx) <
5:
-
continue
-
-
# 寻找轮廓的顶点
-
defects = cv2.convexityDefects(approx, hull)
-
vertices = []
-
for i
in
range(defects.shape[
0]):
-
s, e, f, d = defects[i,
0]
-
start =
tuple(approx[s][
0])
-
end =
tuple(approx[e][
0])
-
far =
tuple(approx[f][
0])
-
vertices.append(far)
-
-
# 对轮廓进行拟合
-
lines = cv2.fitLine(np.array(vertices), cv2.DIST_L2,
0,
0.01,
0.01)
-
-
# 绘制拟合直线
-
x0, y0 =
int(lines[
2] - lines[
0] *
100),
int(lines[
3] - lines[
1] *
100)
-
x1, y1 =
int(lines[
2] + lines[
0] *
100),
int(lines[
3] + lines[
1] *
100)
-
cv2.line(img, (x0, y0), (x1, y1), (
0,
255,
0),
2)
-
-
cv2.imshow(
'image', img)
-
cv2.waitKey(
0)
-
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/6df82/6df82267e8fb9ee35907757636aeb1d5cf0c168f" alt=""
data:image/s3,"s3://crabby-images/3e771/3e771b1fe2a3b547e6eb5076b76ecf9766884b87" alt=""
-
import cv2
-
import numpy
as np
-
-
# 读取图片
-
img = cv2.imread(
'example.png')
-
-
# 转为灰度图
-
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
-
-
# 二值化处理
-
ret, binary = cv2.threshold(gray,
127,
255, cv2.THRESH_BINARY)
-
-
# 查找轮廓
-
contours, hierarchy = cv2.findContours(binary, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
-
-
# 对轮廓点集合按照横坐标排序
-
contour_points = contours[
0]
-
contour_points = contour_points[np.argsort(contour_points[:, :,
0])]
-
-
# 分离轮廓点集合
-
mid_x = (contour_points[
0][
0][
0] + contour_points[-
1][
0][
0]) //
2
-
left_points = contour_points[
0:mid_x, :, :]
-
right_points = contour_points[mid_x:, :, :]
-
-
# 拟合左侧直线
-
left_vx, left_vy, left_x, left_y = cv2.fitLine(left_points, cv2.DIST_L2,
0,
0.01,
0.01)
-
-
# 拟合右侧直线
-
right_vx, right_vy, right_x, right_y = cv2.fitLine(right_points, cv2.DIST_L2,
0,
0.01,
0.01)
-
-
# 计算直线的截距和斜率
-
left_k = left_vy / left_vx
-
left_b = left_y[
0][
0] - left_k * left_x[
0][
0]
-
right_k = right_vy / right_vx
-
right_b = right_y[
0][
0] - right_k * right_x[
0][
0]
-
-
# 画出拟合的直线
-
height, width, _ = img.shape
-
left_x0 =
0
-
left_y0 =
int(left_k * left_x0 + left_b)
-
left_x1 = width
-
left_y1 =
int(left_k * left_x1 + left_b)
-
right_x0 =
0
-
right_y0 =
int(right_k * right_x0 + right_b)
-
right_x1 = width
-
right_y1 =
int(right_k * right_x1 + right_b)
-
cv2.line(img, (left_x0, left_y0), (left_x1, left_y1
data:image/s3,"s3://crabby-images/2af26/2af26fe480f5ee7b32305326559c3b9e82d56d90" alt=""
-
import cv2
-
import numpy
as np
-
-
# 读入图像
-
img = cv2.imread(
"example.jpg")
-
-
# 灰度化和边缘检测
-
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
-
edges = cv2.Canny(gray,
50,
150, apertureSize=
3)
-
-
# 获取轮廓
-
contours, hierarchy = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
-
-
# 对每个轮廓进行拟合
-
for contour
in contours:
-
# 拟合直线
-
[vx, vy, x, y] = cv2.fitLine(contour, cv2.DIST_L2,
0,
0.01,
0.01)
-
slope = vy / vx
-
y_intercept = y - slope * x
-
x1 =
0
-
y1 =
int(x1 * slope + y_intercept)
-
x2 = img.shape[
1] -
1
-
y2 =
int(x2 * slope + y_intercept)
-
cv2.line(img, (x1, y1), (x2, y2), (
0,
0,
255),
2)
-
-
[vx, vy, x, y] = cv2.fitLine(contour, cv2.DIST_L2,
0,
0.01,
0.01)
-
slope = vy / vx
-
y_intercept = y - slope * x
-
x1 =
0
-
y1 =
int(x1 * slope + y_intercept)
-
x2 = img.shape[
1] -
1
-
y2 =
int(x2 * slope + y_intercept)
-
cv2.line(img, (x1, y1), (x2, y2), (
0,
0,
255),
2)
-
-
# 显示结果
-
cv2.imshow(
"result", img)
-
cv2.waitKey(
0)
-
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/cf6fa/cf6fac3ef62bd9202fbf998ee4157729a27c145c" alt=""
data:image/s3,"s3://crabby-images/2b664/2b664baafcb72ad212b105eaaf17601fb0d24236" alt=""
-
import cv2
-
import numpy
as np
-
-
# 读入图片,转为灰度图
-
img = cv2.imread(
"image.jpg")
-
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
-
-
# Canny 边缘检测
-
edges = cv2.Canny(gray,
50,
150)
-
-
# 寻找轮廓
-
contours, _ = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
-
-
# 画出轮廓
-
contour_img = np.zeros_like(img)
-
cv2.drawContours(contour_img, contours, -
1, (
0,
255,
0),
3)
-
-
# 对每个轮廓拟合两条直线
-
line_img = np.zeros_like(img)
-
for cnt
in contours:
-
# 拟合第一条直线
-
[vx, vy, x, y] = cv2.fitLine(cnt, cv2.DIST_L2,
0,
0.01,
0.01)
-
lefty =
int((-x * vy / vx) + y)
-
righty =
int(((img.shape[
1] - x) * vy / vx) + y)
-
cv2.line(line_img, (img.shape[
1]-
1, righty), (
0, lefty), (
255,
0,
0),
2)
-
-
# 拟合第二条直线
-
[vx, vy, x, y] = cv2.fitLine(cnt, cv2.DIST_L2,
0,
0.01,
0.01)
-
lefty =
int((-x * vy / vx) + y)
-
righty =
int(((img.shape[
1] - x) * vy / vx) + y)
-
cv2.line(line_img, (img.shape[
1]-
1, righty), (
0, lefty), (
0,
0,
255),
2)
-
-
# 显示结果
-
cv2.imshow(
"Contour", contour_img)
-
cv2.imshow(
"Lines", line_img)
-
cv2.waitKey(
0)
-
cv2.destroyAllWindows()
data:image/s3,"s3://crabby-images/f5ecb/f5ecbc9357cd099e6e9274d9a1fe97ebd009d74e" alt=""
同样的问题,实现的方式有多种;在编写程序需求时,明确一下思路,它写出来的代码会更符合我们所想的。
data:image/s3,"s3://crabby-images/e81b3/e81b347172d30bcb32e46df1c31591c4aab0e8c6" alt=""
-
import cv2
-
import numpy
as np
-
-
# 读取图片并进行灰度化处理
-
img = cv2.imread(
'test.png')
-
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
-
-
# 对灰度图像进行边缘检测,如使用 Canny 算法
-
edges = cv2.Canny(gray,
50,
150)
-
-
# 找到所有轮廓,并选择一个想要拟合的轮廓
-
contours, hierarchy = cv2.findContours(edges, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
-
cnt = contours[
0]
-
-
# 对轮廓进行逼近,得到轮廓的拟合线段
-
epsilon =
0.1 * cv2.arcLength(cnt,
True)
-
approx = cv2.approxPolyDP(cnt, epsilon,
True)
-
-
# 计算轮廓的重心坐标
-
M = cv2.moments(cnt)
-
cx =
int(M[
'm10']/M[
'm00'])
-
cy =
int(M[
'm01']/M[
'm00'])
-
-
# 将轮廓点集合分为左右两部分
-
left_cnt = []
-
right_cnt = []
-
for i
in
range(
len(cnt)):
-
if cnt[i][
0][
0] < cx:
-
left_cnt.append(cnt[i])
-
else:
-
right_cnt.append(cnt[i])
-
-
left_cnt = np.array(left_cnt)
-
right_cnt = np.array(right_cnt)
-
-
# 对左右两部分的点分别进行拟合直线
-
[vx_l, vy_l, x_l, y_l] = cv2.fitLine(left_cnt, cv2.DIST_L2,
0,
0.01,
0.01)
-
[vx_r, vy_r, x_r, y_r] = cv2.fitLine(right_cnt, cv2.DIST_L2,
0,
0.01,
0.01)
-
-
# 得到拟合直线的参数,可以使用直线的一般式或截距式表示
-
k_l = vy_l / vx_l
-
b_l = y_l - k_l * x_l
-
k_r = vy_r / vx_r
-
b_r =
data:image/s3,"s3://crabby-images/288f4/288f42df48e41fad547703e223cd68730d53f6fd" alt=""
这个代码没写完,又被中断了;感觉写稍微长一些的代码,就容易出现中断的情况。
总体感受
对于简单的运算,感觉不错的,能清晰介绍原理,然后写示例程序,还给出了示例的运行结果。
在示例程序中,要求程序详细一些时,它会写得很详细些,这个不错的。
对于一些特定领域的知识,它也是知道的,能根据描述需求,写出示例程序。
有些复杂一些的运算,它写出的程序会报错;这个需要我们检测和修正。
写稍微长一些的代码,就容易出现中断的情况,代码还没写完呢。
总体感觉挺挺强的,适合我们去了解一个新的知识(原理和思路),然后参考它的示例程序。
转载:https://blog.csdn.net/qq_41204464/article/details/129151022
查看评论