新网创想网站建设,新征程启航

为企业提供网站建设、域名注册、服务器等服务

python编写分段函数的方法-创新互联

简介:

成都创新互联是一家专业提供福安企业网站建设,专注与成都做网站、网站设计、外贸营销网站建设html5、小程序制作等业务。10年已为福安众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。

分段函数,就是对于自变量x的不同的取值范围,有着不同的解析式的函数。它是一个函数,而不是几个函数;分段函数的定义域是各段函数定义域的并集,值域也是各段函数值域的并集。

python编写分段函数的方法:

1.绘制分段函数:y=4sin(4πt)-sgn(t-0.3)-sgn(0.72-t)

代码:

#!/usr/bin/python
# -*- coding:utf-8 -*-
import numpy as np
import matplotlib.pyplot as plt
#绘制分段函数:y=4sin(4πt)-sgn(t-0.3)-sgn(0.72-t)
def sgn(x):
    if x > 0:
        return 1
    elif x < 0:
        return -1
    else:
        return 0
t = np.arange(0, 1, 0.01)
y = []
for i in t:
    y_1 = 4 * np.sin(4 * np.pi * i) - sgn(i - 0.3) - sgn(0.72 - i)
    y.append(y_1)
plt.plot(t, y)
plt.xlabel("t")
plt.ylabel("y")
plt.title("Heavsine")
plt.show()

2.使用Matplotlib绘制分段函数:

代码:

#!/usr/bin/python
# -*- coding:utf-8 -*-
import numpy as np
import matplotlib.pyplot as plt
def sgn(value):
    if value < 4:
        return 20
    else:
        return 15
plt.figure(figsize=(6, 4))
x = np.linspace(0, 8, 100)
y = np.array([])
for v in x:
    y = np.append(y, np.linspace(sgn(v), sgn(v), 1))
l = plt.plot(x, y, 'b', label='type')
plt.legend()
plt.show()

3.绘制三角波形:

#!/usr/bin/python
# -*- coding:utf-8 -*-
import numpy as np
import matplotlib.pyplot as plt
def triangle_wave(x, c, c0, hc):
   x = x - int(x)  #三角波周期为1 因此只取小数部分进行计算
   if x < c0:
       return x / c0 * hc
   elif x >= c:
       return 0.0
   else:
       return (c-x)/(c-c0)*hc
x = np.linspace(0, 2, 1000)
y = np.array([triangle_wave(t, 0.6, 0.4, 1.0) for t in x])
plt.figure()
plt.plot(x, y)
plt.ylim(-0.2, 1.2)   #限制y的范围
plt.show()

以上就是python分段函数如何编写?的详细内容,更多请关注创新互联其它相关文章!


网站栏目:python编写分段函数的方法-创新互联
标题链接:http://www.wjwzjz.com/article/ccigos.html
在线咨询
服务热线
服务热线:028-86922220
TOP