动力学法测量金属弹性模量

🏫中南民族大学-⚛大学物理实验2-📠通信工程2024

目录

Python代码

1. 绘制图像

2. 弹性模量数值计算

 图像显示


Pycharm + 豆包 MarsCode 非常强大!有了它们,我在处理大学物理实验的数据及其可视化就非常方便,极大缩减了我的学习成本。Excel 也能绘图但是不够灵活,MatplotlibSeaborn等Python库能减少计算量,提供更加多样化的选择👍。

Python代码

1. 绘制图像

# 动力学法测量金属的弹性模量
# 绘图
import math
import numpy as np
import seaborn as sns
import matplotlib.pyplot as pltd1 = [5.980, 5.985, 5.985, 5.989, 5.985, 5.985]
d2 = [5.805, 5.795, 5.795, 5.781, 5.783, 5.785]# 计算平均值
mean_d1 = np.mean(d1)
mean_d2 = np.mean(d2)
print(f"数据集d1的平均值为:{mean_d1:.3f}")
print(f"数据集d2的平均值为:{mean_d2:.3f}\n")# 计算标准差
standard_deviation_d1 = np.std(d1, ddof=1)
standard_deviation_d2 = np.std(d2, ddof=1)
print(f"数据集d1的标准差为:{standard_deviation_d1:.3f}")
print(f"数据集d2的标准差为:{standard_deviation_d2:.3f}\n")# 计算不确定度
Ud1 = math.sqrt(standard_deviation_d1 ** 2 + 0.004 ** 2)
Ud2 = math.sqrt(standard_deviation_d2 ** 2 + 0.004 ** 2)
print(f"数据集d1的不确定度为:{Ud1:.3f}")
print(f"数据集d2的不确定度为:{Ud2:.3f}\n")# x/l
l = 180.05
x = [25, 30, 35, 42.5, 45, 50, 55]
# 计算x/l
x_l = []
for i in range(len(x)):x_l.append(x[i] / l)print(f"x/l_{i + 1}={x_l[i]:.3f}", end="     ")# 频率
f_Cu = [610.560, 610.401, 610.010, 609.751, 609.880, 610.320, 612.090]
f_Al = [819.021, 816.581, 815.411, 814.761, 814.901, 815.731, 817.411]# 绘制散点图
plt.figure(figsize=(12, 6))# 第一个子图:x_l 和 f_Cu
plt.subplot(1, 2, 1)
sns.scatterplot(x=x_l, y=f_Cu, label='Cu')# 用二次曲线拟合数据
# 我们使用 numpy 的 polyfit 函数来拟合二次曲线
coefficients = np.polyfit(x_l, f_Cu, 2)
# 得到x/l=0.224的频率
a, b, c = coefficients
# 计算 x/l=0.224 时的 f_Al 值
x_0224 = 0.224
f_Cu_0224 = a * x_0224 ** 2 + b * x_0224 + c
# 输出结果
print(f"The value of f_Cu at x/l=0.224 is: {f_Cu_0224:.3f}")# 生成拟合曲线的 x 值
x_fit = np.linspace(min(x_l), max(x_l), 100)
# 根据拟合曲线的系数计算 y 值
y_fit = np.polyval(coefficients, x_fit)# 绘制拟合曲线
sns.lineplot(x=x_fit, y=y_fit, color='#B5A642', label='Quadratic Fit')# 标注 x/l = 0.224 的点
plt.scatter(0.224, f_Cu_0224, color='green', marker='o', s=100, label='x/l = 0.224')
# 添加注释显示坐标
plt.annotate(f'({0.224}, {f_Cu_0224:.3f})', xy=(0.224, f_Cu_0224), xytext=(0.224, f_Cu_0224 - 0.1))plt.title('Scatter Plot of x/l vs. f_Cu with Quadratic Fit')
plt.xlabel('x/l', fontweight='bold')
plt.ylabel('f_Cu/Hz', fontweight='bold')
plt.legend()
plt.grid(True)# 第二个子图:x_l 和 f_Al
plt.subplot(1, 2, 2)
sns.scatterplot(x=x_l, y=f_Al, label='Al')# 用二次曲线拟合数据
# 我们使用 numpy 的 polyfit 函数来拟合二次曲线
coefficients = np.polyfit(x_l, f_Al, 2)
# 得到x/l=0.224的频率
a, b, c = coefficients
# 计算 x/l=0.224 时的 f_Al 值
x_0224 = 0.224
f_Al_0224 = a * x_0224 ** 2 + b * x_0224 + c
# 输出结果
print(f"The value of f_Al at x/l=0.224 is: {f_Al_0224:.3f}")# 生成拟合曲线的 x 值
x_fit = np.linspace(min(x_l), max(x_l), 100)
# 根据拟合曲线的系数计算 y 值
y_fit = np.polyval(coefficients, x_fit)# 绘制拟合曲线
sns.lineplot(x=x_fit, y=y_fit, color='grey', label='Quadratic Fit')# 标注 x/l = 0.224 的点
plt.scatter(0.224, f_Al_0224, color='green', marker='o', s=100, label='x/l = 0.224')
# 添加注释显示坐标
plt.annotate(f'({0.224}, {f_Al_0224:.3f})', xy=(0.224, f_Al_0224), xytext=(0.224, f_Al_0224 - 0.15))plt.title('Scatter Plot of x/l vs. f_Al with Quadratic Fit')
plt.xlabel('x/l', fontweight='bold')
plt.ylabel('f_Al/Hz', fontweight='bold')
plt.legend()
plt.grid(True)# 调整子图布局
plt.tight_layout()# 显示图形
plt.show()

2. 弹性模量数值计算

# 动力学法测量计算金属弹性模量
# 数值计算# 弹性模量
# Cu
# l = 180.1 * 1e-3
# m = 42.46 * 1e-3
# d = 5.985 * 1e-3
# f = 609.708# Al
l = 180.0 * 1e-3
m = 13.25 * 1e-3
d = 5.791 * 1e-3
f = 814.722E = 1.6067 * pow(l, 3) * m * pow(f, 2) / pow(d, 4)# 不确定度
# Cu
# Ul = 0.02 * 1e-3
# Um = 0.01 * 1e-3
# Ud = 0.005 * 1e-3
# Uf = 0.0005# Al
Ul = 0.02 * 1e-3
Um = 0.01 * 1e-3
Ud = 0.010 * 1e-3
Uf = 0.0005temp = pow(3 / l, 2) * pow(Ul, 2) + pow(1 / m, 2) * pow(Um, 2) + pow(4 / d, 2) * pow(Ud, 2) + pow(2 / f, 2) * pow(Uf, 2)
U = E * pow(temp, 1 / 2)print(f"弹性模量为:{E}")
print(f"不确定度为:{U}")

 

 图像显示

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/61324.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NLP论文速读(EMNLP 2024)|动态奖励与提示优化来帮助语言模型的进行自我对齐

论文速读|Dynamic Rewarding with Prompt Optimization Enables Tuning-free Self-Alignment of Language Models 论文信息: 简介: 本文讨论的背景是大型语言模型(LLMs)的自我对齐问题。传统的LLMs对齐方法依赖于昂贵的训练和人类偏好注释&am…

SLM561A系列60V10-50mA单通道线性恒流LED驱动芯片,为汽车照明、景观照明助力

SLM561A系列选型参考: SLM561A10ae-7G SOD123 SLM561A15ae-7G SOD123 SLM561A20ae-7G SOD123 SLM561A25ae-7G SOD123 SLM561A30ae-7G SOD123 SLM561A35ae-7G SOD123 SLM561A40ae-7G SOD123 SLM561A45ae-7G SOD123 SLM561A50ae-7G SOD123 S…

RabbitMQ1:初识MQ

欢迎来到“雪碧聊技术”CSDN博客! 在这里,您将踏入一个专注于Java开发技术的知识殿堂。无论您是Java编程的初学者,还是具有一定经验的开发者,相信我的博客都能为您提供宝贵的学习资源和实用技巧。作为您的技术向导,我将…

父组件提交时让各自的子组件验证表格是否填写完整

项目场景: 提示:这里简述项目相关背景: 父组件中有三个表格,表格中时输入框,有些输入框是必填的,在父组件提交时需要验证这三个表格的必填输入框中是否有没填写的。 原因分析: 提示&#xff1a…

Siglus引擎 Unpack | 未完待续

前言 未完待续。 代码在这里:https://github.com/N0zoM1z0/SiglusEngine-Extract 以后随时会更新。() 因为我是选择直接逆向游戏引擎,在无源码,不hook的情况下硬逆Siglus…… 路漫漫。。。 read.sav 可以直接逆Sigl…

黑马嵌入式开发入门模电基础学习笔记

学习视频: 黑马程序员嵌入式开发入门模电(模拟电路)基础 文章目录 背景介绍电流电压组件仿真三极管ne555PCBEDA案例:非接触式电笔案例:电子琴 背景介绍 电流 电压 组件 仿真 三极管 mos管 ne555 PCB EDA 案例:非接触…

linux 中mysql查看慢日志

1、到mysql容器,先登录到数据库,查看是否开启 mysql -h 127.0.0.1 -uroot -p SHOW VARIABLES LIKE slow_query_log; 2、如果没有开启,需要先开启 set global slow_query_log ON; 3、查看慢日志文件 SHOW VARIABLES LIKE slow_query_log…

从0开始机器学习--Day30--异常检测算法

异常检测算法(Anomaly detection algorithm) 我们定义异常检测算法的输出,也写作,这里的每一项括号内代表的是每个特征都符合各自的高斯分布(也就是正态分布),代表均值,决定了模型的中心位置;代…

架构图解析:如何构建高效的微服务系统

在当今的数字化浪潮中,构建高效、灵活且可扩展的系统已成为企业的重要目标。微服务架构作为一种先进的软件设计模式,通过将复杂的应用程序分解为一系列小型、独立的服务,显著提升了系统的灵活性、可扩展性和维护性。本文将通过解析微服务系统…

排序排序的概念及其运用和选择排序

排序排序的概念及其运用和选择排序 7. 排序7.1 排序的概念及其运用7.2 选择排序算法——直接选择排序选择排序基本思想:直接选择排序选择排序原理参考程序 如何交换数据直接选择排序的特性总结: 7. 排序 7.1 排序的概念及其运用 排序:所谓排…

Websocket如何分块处理数据量超大的消息体

若我们服务端一次性最大处理的字节数是1M,而客户端发来了2M的数据,此时服务端的数据就要被切割成两次传输解码。Http协议中有分块传输,而在Websocket也可以分块处理超大的消息体。在jsr356标准中使用javax.websocket.MessageHandler.Partial可以分块处理…

【澜舟科技-注册/登录安全分析报告】

前言 由于网站注册入口容易被机器执行自动化程序攻击,存在如下风险: 暴力破解密码,造成用户信息泄露,不符合国家等级保护的要求。短信盗刷带来的拒绝服务风险 ,造成用户无法登陆、注册,大量收到垃圾短信的…

uni-app快速入门(十)--常用内置组件(下)

本文介绍uni-app的textarea多行文本框组件、web-view组件、image图片组件、switch开关组件、audio音频组件、video视频组件。 一、textarea多行文本框组件 textarea组件在HTML 中相信大家非常熟悉,组件的官方介绍见: textarea | uni-app官网uni-app,un…

Tomcat 如何管理 Session

Tomcat 如何管理 Session 我们知道,Tomcat 中每一个 Context 容器对应一个 Web 应用,而 Web 应用之间的 Session 应该是独立的,因此 Session 的管理肯定是 Context 级的,也就是一个 Context 一定关联多个 Session。 Tomcat 中主…

鸿蒙NEXT开发-用户通知服务的封装和文件下载通知

注意:博主有个鸿蒙专栏,里面从上到下有关于鸿蒙next的教学文档,大家感兴趣可以学习下 如果大家觉得博主文章写的好的话,可以点下关注,博主会一直更新鸿蒙next相关知识 专栏地址: https://blog.csdn.net/qq_56760790/…

01 IP路由基础

一、路由器是怎么转发数据包 • 当数据包到达路由器之后,根据数据包的目的 IP 地址,查找 路由表,并根据路由表中相应的路由所指示出接口还有下一跳 指导数据包在网络中的转发。 • 如果路由器路由表没有路由怎么办? -------- 将数…

Android studio 呼叫盒app

一、权限文件 0.gradle切换国内源 #Fri Nov 08 15:46:05 CST 2024 distributionBaseGRADLE_USER_HOME distributionPathwrapper/dists distributionUrlhttps://mirrors.cloud.tencent.com/gradle/gradle-8.4-bin.zip zipStoreBaseGRADLE_USER_HOME zipStorePathwrapper/dists1…

[Admin] Dashboard Filter for Mix Report Types

Background RevOps team has built a dashboard for sales team to track team members’ performance, but they’re blocked by how to provide a manager view based on sales’ hierarchy. Therefore, they seek for dev team’s help to clear their blocker. From foll…

2024年人工智能技术赋能网络安全应用测试:广东盈世在钓鱼邮件识别场景荣获第三名!

近期,2024年国家网络安全宣传周“网络安全技术高峰论坛主论坛暨粤港澳大湾区网络安全大会”在广州成功举办。会上,国家计算机网络应急技术处理协调中心公布了“2024年人工智能技术赋能网络安全应用测试结果”。结果显示,广东盈世计算机科技有…

Java进阶四-异常,File

异常 概念:代表程序出现的问题。 目的:程序出现了异常我们应该如何处理。 最高父类:Exception 异常分为两类 编译时异常:没有继承RuntimeException的异常,直接继承与Exception,编译阶段就会错误提示。运行时异常:RuntimeExc…