参数方程、椭圆、柯西中值定理的道与术
793 2023-02-25 13:55
竟然画出椭圆了
import numpy as np
import matplotlib.pyplot as plt
if __name__ == "__main__":
n = 1
t = np.arange(0, 2 * np.pi * n, 0.01)
r = 5
x = r * np.cos(t) * 1.2
y = r * np.sin(t)
plt.plot(x, y)
# 设置x,y坐标轴的刻度显示范围
plt.xlim(-8, 8)
plt.ylim(-8, 8)
# 手动调整label顺序
# handles, labels = plt.gca().get_legend_handles_labels()
# order = [1, 0]
# plt.legend([handles[idx] for idx in order], [labels[idx] for idx in order])
# # 显示图例说明
# plt.legend()
# 获取当前坐标轴gca即get current axis
ax = plt.gca()
# 去掉上、右二侧的边框线
ax.spines['top'].set_color('none')
ax.spines['right'].set_color('none')
# 将左侧的y轴,移到x=0的位置
ax.spines['left'].set_position(('data', 0))
# 将下面的x轴,移到y=0的位置
ax.spines['bottom'].set_position(('data', 0))
# 调整x轴刻度(从-5到+5,正好9个点)
plt.xticks(np.linspace(-7, 7, 15))
# 调整y轴刻度
plt.yticks(np.linspace(-7, 7, 15))
# 给纵坐标轴加箭头
plt.arrow(0, 8, 0, 0, width=0.2, color="k", clip_on=False, head_width=0.2, head_length=0.2)
# 给横坐标轴加箭头
plt.arrow(8, 0, 0.01, 0, width=0.2, color="k", clip_on=False, head_width=0.2, head_length=0.2)
plt.show()
椭圆2
import numpy as np
import matplotlib.pyplot as plt
if __name__ == "__main__":
n = 1
t = np.arange(0, 2 * np.pi * n, 0.01)
r = 5
x = r * np.cos(t + 1.2)
y = r * np.sin(t)
plt.plot(x, y)
# 设置x,y坐标轴的刻度显示范围
plt.xlim(-8, 8)
plt.ylim(-8, 8)
# 手动调整label顺序
# handles, labels = plt.gca().get_legend_handles_labels()
# order = [1, 0]
# plt.legend([handles[idx] for idx in order], [labels[idx] for idx in order])
# # 显示图例说明
# plt.legend()
# 获取当前坐标轴gca即get current axis
ax = plt.gca()
# 去掉上、右二侧的边框线
ax.spines['top'].set_color('none')
ax.spines['right'].set_color('none')
# 将左侧的y轴,移到x=0的位置
ax.spines['left'].set_position(('data', 0))
# 将下面的x轴,移到y=0的位置
ax.spines['bottom'].set_position(('data', 0))
# 调整x轴刻度(从-5到+5,正好9个点)
plt.xticks(np.linspace(-7, 7, 15))
# 调整y轴刻度
plt.yticks(np.linspace(-7, 7, 15))
# 给纵坐标轴加箭头
plt.arrow(0, 8, 0, 0, width=0.2, color="k", clip_on=False, head_width=0.2, head_length=0.2)
# 给横坐标轴加箭头
plt.arrow(8, 0, 0.01, 0, width=0.2, color="k", clip_on=False, head_width=0.2, head_length=0.2)
plt.show()
竟然画出阿基米德螺旋线
import numpy as np
import matplotlib.pyplot as plt
if __name__ == "__main__":
n = 4/5
theta = np.arange(0, 2 * np.pi * n, 0.01)
alpha = 3
beta = 4
r = alpha + beta * theta
x = r * np.cos(theta)
y = r * np.sin(theta)
plt.plot(x, y)
# 设置x,y坐标轴的刻度显示范围
plt.xlim(-31, 31)
plt.ylim(-31, 31)
# 手动调整label顺序
# handles, labels = plt.gca().get_legend_handles_labels()
# order = [1, 0]
# plt.legend([handles[idx] for idx in order], [labels[idx] for idx in order])
# 显示图例说明
# plt.legend()
# 获取当前坐标轴gca即get current axis
ax = plt.gca()
# 去掉上、右二侧的边框线
ax.spines['top'].set_color('none')
ax.spines['right'].set_color('none')
# 将左侧的y轴,移到x=0的位置
ax.spines['left'].set_position(('data', 0))
# 将下面的x轴,移到y=0的位置
ax.spines['bottom'].set_position(('data', 0))
# 调整x轴刻度(从-5到+5,正好9个点)
plt.xticks(np.linspace(-30, 30, 11))
# 调整y轴刻度
plt.yticks(np.linspace(-30, 30, 11))
# 给纵坐标轴加箭头
plt.arrow(0, 31, 0, 0, width=0.2, color="k", clip_on=False, head_width=0.2, head_length=0.2)
# 给横坐标轴加箭头
plt.arrow(31, 0, 0.01, 0, width=0.2, color="k", clip_on=False, head_width=0.2, head_length=0.2)
plt.show()
等高线画椭圆
import matplotlib.pyplot as plt
import numpy as np
a, b = 7.79, 0.50
c, d = -4.50, 0.87
# 构造等高线函数
def f(x, y):
return a * x ** 2 + b * x * y + c * y * x + d * y ** 2 - 1
# 定义点的数量
n = 500
# 作点
x = np.linspace(-3.5, 3.5, n)
y = np.linspace(-3.5, 3.5, n)
# 构造网格
X, Y = np.meshgrid(x, y)
# text方式的文本
# plt.text(-2, 1, r'$2x^2+(-1)xy+(-1)xy+2y^2=1$', fontdict={'size': 16, 'color': 'g'})
# 获取当前坐标轴gca即get current axis
ax = plt.gca()
# 去掉上、右二侧的边框线
ax.spines['top'].set_color('none')
ax.spines['right'].set_color('none')
# 将左侧的y轴,移到x=0的位置
ax.spines['left'].set_position(('data', 0))
ax.spines['bottom'].set_position(('data', 0))
# 调整x轴刻度(从-5到+5,正好11个点)
plt.xticks(np.linspace(-3, 3, 7))
# 调整y轴刻度
plt.yticks(np.linspace(-3, 3, 7))
# 给坐标轴加箭头
plt.arrow(0, 3.5, 0, 0, width=0.2, color="k", clip_on=False, head_width=0.2, head_length=0.2)
plt.arrow(3.5, 0, 0.01, 0, width=0.2, color="k", clip_on=False, head_width=0.2, head_length=0.2)
# 绘制等高线,8表示等高线数量加1
plt.contour(X, Y, f(X, Y), 0)
# plt.plot(x, y)
plt.show()
旋转矩阵的计算:
二阶矩阵相乘-20220621-手动横向输入-pre3
# 普通矩阵相乘
m, p, n = map(int, "2, 2, 2".split(",")) # 获得两个矩阵的行列数
A = []
B = [] # 创建A,B两个空列表,用以存放相乘的两个矩阵
C = [[0 for i in range(n)] for j in range(m)] # 创建一个m行n列的初始化矩阵
print("请输入第1个矩阵:")
for i in range(1):
A = list(map(float, (input().strip().split(" ")))) # 获得A矩阵
A1 = [A[0], A[1]]
A2 = [A[2], A[3]]
A = [A1, A2]
print("请输入第2个矩阵:")
for i in range(1):
B = list(map(float, input().strip().split(" "))) # 获得B矩阵
B1 = [B[0], B[1]]
B2 = [B[2], B[3]]
B = [B1, B2]
for i in range(m):
for j in range(n):
for k in range(p):
C[i][j] += A[i][k] * B[k][j] # 根据矩阵相乘的运算规则进行运算
for s in C:
print() # 保证输出为矩阵形式
for r in s:
print(r, end=" ") # 输出结果矩阵
求一个二阶矩阵的逆矩阵-20220622-手动横向输入版-pre3
m, n = map(int, "2, 2".split(",")) # 获得两个矩阵的行列数
A = []
print("请输入一个矩阵:")
for i in range(1):
A = list(map(float, (input().strip().split(" ")))) # 获得A矩阵
A1 = [A[0], A[1]]
A2 = [A[2], A[3]]
A = [A1, A2]
a = A[0][0]
b = A[0][1]
c = A[1][0]
d = A[1][1]
T1 = [a, b]
T2 = [c, d]
T = [T1, T2]
# print("初始矩阵是:")
# for s in T:
# print() # 保证输出为矩阵形式
# for r in s:
# print(r, end=" ") # 输出结果矩阵
# print()
fenmu = a * d - b * c
# print("分母是:", fenmu)
T[0][0] = round(d / fenmu, 3)
T[0][1] = round(-b / fenmu, 3)
T[1][0] = round(-c / fenmu, 3)
T[1][1] = round(a / fenmu, 3)
print("\r\n\r\n其逆矩阵是:")
for s in T:
print() # 保证输出为矩阵形式
for r in s:
print(r, end=" ") # 输出结果矩阵
全部评论