浙商智选经济动能混合c:绘制相对论动能(kinetic energy graph)

关于浙商智选经济动能混合c的问题,在kinetic energy graph中经常遇到, 我写了一个计算相对论动能的函数,但我在绘制它时遇到了一些问题。

我写了一个计算相对论动能的函数,但我在绘制它时遇到了一些问题。

我使用泰勒的v非常小的值(所以我不会因为取消而导致E= 0)和最大值的原始表达式。我必须在 1e-6 和 2.88 e8 之间计算v

m=1
c=3e8
def E(v):
    if (v/c) <= 0.8860:
        return ((m*v**2)/2) + ((3*m*v**4)/(8*c**2)) + ((5*m*v**6)/(16*c**4)) + ((35*m*v**8)/(128*c**6))
    else:
        return (m*c**2)*((1/sp.sqrt(1-(v**2/c**2)))-1)

这给了我非常准确的结果。现在问题是 graphingE(v)。我必须使用 matplotlib (+ numpy 和 scipy for everything else)。这是我为 log-log 图编写的内容。

xs = np.logspace(-6, 8.5)
fig, ax = plt.subplots(figsize=[10,10])   
ax.plot(xs, E(xs))
ax.set_xscale('log')
ax.set_yscale('log')

我得到一个值错误:

 "ValueError: The truth value of an array with more than one element
  is ambiguous. Use a.any() or a.all()", and it points at "if (v/c) <= 0.8860:".

这个错误是什么意思,我做错了。如果你能帮我绘制图形或更改我的功能,我将非常感激。

0

您需要创建一个循环,而不仅仅是一个条件:

m=1
c=3e8
def E(v):
    for i in range(len(v)):
        if (v[i]/c) <= 0.8860:
            return ((m*v**2)/2) + ((3*m*v**4)/(8*c**2)) + ((5*m*v**6)/(16*c**4)) + ((35*m*v**8)/(128*c**6))
        else:
            return (m*c**2)*((1/sp.sqrt(1-(v**2/c**2)))-1)
xs = np.logspace(-6, 8.5)
fig, ax = plt.subplots(figsize=[10,10])   
ax.plot(xs, E(xs))
ax.set_xscale('log')
ax.set_yscale('log')

该条件应为“v”的值,以与 0.8860 进行比较。当提供具有多个值的数组时,它说它不能为数组提供 True 或 False。all()和 any()是从列表或数组中提取 True 或 False 的方法:any()将给出 True,如果任何为 True,则 all()仅在全部为 True 时。

0

语句if (v/c) <= 0.8860没有很好地定义,因为对于v中的某些值,这是True对于其他值,它是False。这有点像问“人们身高超过 1.8 米吗?”没有明确的答案;有些是,有些不是。错误告诉您要指定的条件是:您想知道所有人都比 1.8 大吗?

您可以使用numpy.piecewise为某些条件定义不同的函数。还要注意,v的条目不应大于c,因为这将导致无限的能量。

import numpy as np
import matplotlib.pyplot as plt
m=1
c=3.e8
lowv = lambda v:((m*v**2)/2) + ((3*m*v**4)/(8*c**2)) + ((5*m*v**6)/(16*c**4)) + ((35*m*v**8)/(128*c**6))
highv = lambda v:(m*c**2)*(1./np.sqrt(1-(v/c)**2)-1)
E = lambda v : np.piecewise(v, [(v/c) <= 0.8860, (v/c) > 0.8860], [lowv,highv])
xs = 2.9999*np.logspace(-6, 8, num=1000)
fig, ax = plt.subplots(figsize=[10,10])   
ax.plot(xs, E(xs))
ax.set_xscale('log')
ax.set_yscale('log')
plt.show()

enter image description here

或者,您可以使用numpy.vectorizev中的每个条目单独评估现有函数。这当然效率较低,不应用于大型数组。

import numpy as np
import matplotlib.pyplot as plt
m=1
c=3.e8
def E(v):
    if (v/c) <= 0.8860:
        return ((m*v**2)/2) + ((3*m*v**4)/(8*c**2)) + ((5*m*v**6)/(16*c**4)) + ((35*m*v**8)/(128*c**6))
    else:
        return (m*c**2)*((1/np.sqrt(1-(v**2/c**2)))-1)
Ev = np.vectorize(E)
xs = 2.9999*np.logspace(-6, 8, num=1000)
fig, ax = plt.subplots(figsize=[10,10])   
ax.plot(xs, Ev(xs))
ax.set_xscale('log')
ax.set_yscale('log')
plt.show()

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(239)
Opc 3:OPCUA和OPC DA的区别
上一篇
社保代码是社保卡上的哪一个:哪一个是更快的对象检测 (fast object detection)
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 94 65
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 15 11
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 43 83
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 57 36
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 37 50
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 53 61
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 18 74
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 24 29

发表评论

登录 后才能评论

评论列表(10条)