程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长

+关注
已关注

分类  

模块(0)

标准库(0)

标签  

标准库模块(0)

字符串(0)

日期归档  

Python代码练习(五):Numpy

发布于2020-02-25 14:19     阅读(979)     评论(0)     点赞(13)     收藏(5)


Python代码练习(五):Numpy

七月在线课程的练习题

  • 简单加法: 在 Python 下对一个二维列表,l1=[[1,2,3],[4,5,6]],然后进行每个元素+1 的操作。 要求使用
    Python循环
    Map函数
    Numpy计算(广播算法)

  • 矩阵转置:
    对 arr= [[1, 2, 3], [4, 5, 6], [7,8, 9], [10, 11, 12]]进行行列互转
    Python列表表达式
    Numpy进行转置

  • 矩阵内部运算
    在Python下对一个二维列表,l1=[[1,2,3],[4,5,6]],要求求出按行与按列求和。
    在numpy下对一个二维列表,l1=[[1,2,3],[4,5,6]],要求求出按行与按列求和。

  • NDArray 创建与属性
    使用Numpy创建一个多维数组,请输出以下属性
    该数组的形状
    该数组的维度
    该数组元素的个数
    该数组的数据类型

  • NDArray 的访问
    创建一个包含从数字 1 到 60,的数组,并将于其形状变为为(3,2,10)的三维数组,并按如下要求访问这个三维数组
    访问第0维度中第二个元素的所有的信息
    访问第0维度中所有元素的全部第0个维度(行),和最后一个维度(列)6-7列
    将该数组降维至二维,形状自行定义
    打乱矩阵内元素的顺序
    按行维度进行排序
    按列维度进行排序
    将降维后的数组进行行列转置
    将转至后的数组展平至一维数组。

  • 拼接与切分 NDArray 对象
    先建立两个矩阵arr1=[[1,2,3],[4,5,6]]和arr2=[[7,8,9],[10,11,12]]
    对两个矩阵进行横向拼接,并输出结果
    对两个矩阵进行纵向拼接,赋值给arr3并输出结果
    对arr3按列进行分割为3个新元素并输出
    对arr3按行进行分割为2个新元素并输出
    将arr3转换为Python列表,并指定数据类型为int

  • 数据导入导出
    生成一个随机数矩阵,形状为(3,5)
    将其第2行第4列的元素修改为998
    保存至本地文件random_matrix.txt
    并尝试从这个文件中载入并验证修改是否正确

  • 使用 numpy 实现 softmax
    思路:
    计算指数,并安全处理避免数字过大
    按行求和
    每行均除以计算的和

  • 股票相关统计量计算
     读入的给定的ibm股价数据中的收盘价及成交量
     计算成交量加权平均价VWAP(收盘价)
     计算时间加权平均价TWAP(收盘价)
     找出IBM股票收盘价的极差
     计算其收盘价的中位数,均值及方差
    计算股票的收益率(简单收益率与对数收益率)
    计算对数收益收益率大于1%的天数有多少?

成交量加权平均价是将多笔交易的价格按各自的成交量加权而算出的平均价,若是计算某一证券在某交易日的 VWAP,将当日成交总值除以总成交量即可。VWAP 可作为交易定价的一种方法,亦可作为衡量机构投资者或交易商 的交易表现的尺度。英文 Volume Weighted Average Price 。
假设某种商品最高价和最低价 2 种,其中最高价 300,占 10%;最低价 200,占 90%。
那该商品的加权平均价为:
a1 对应的是价格,a2 对应的是成交量
时间加权平均也是同样原理,按照越近的日期,所占的权重越高这样的方式去计算。
#普通收益率,注意:不含最后一个交易日的计算
numpy 中的 diff 函数用于行一行之间的求差运算。
对数收益率,取对数可以让数据更平稳,但是不会改变数据间的相关关系。有利于计算。 logreturn=np.diff(np.log©)
计算对数收益大于 1 的交易日 logreturn[logreturn*100>1].size
日期处理
导入文本文件中的股份数据,并将日期转为化对应周几后,再分别去计算从周一到周五的平均价,并找出周几平均 价最高,周几的平均价去低?
数据:ibm 股票数据
提示:自定义日期处理函数,在 loadtxt 的参数中对应处理函数与列。
按周对股票价格进行汇总:
在上一题的基础上选取有连续交易的三周时间(共计 15 天)后,按周进行汇总要求得出每周的开,高,低,收。 提示:numpy 中的 apply_along_axis 函数是高阶函数,能接收处理函数。
c=c[:-1]#对价格顺序进行反转,最新交易日放到最后
numpy.apply_along_axis(func, axis, arr, *args, **kwargs):
必选参数:func,axis,arr。
其中 func 是我们自定义的一个函数,函数 func(arr)中的 arr 是一个数组,函数的主要功能就是对数组里的每 一个元素进行处理,其中 axis 表示函数 func 对数组 arr 作用的轴。可选参数:*args, **kwargs。都是 func()函数额外的参数。返回的是一个根据 func()函数以及维度 axis 运算后得到的的数组.

发布了200 篇原创文章 · 获赞 292 · 访问量 44万+


所属网站分类: 技术文章 > 博客

作者:追梦骚年

链接:https://www.pythonheidong.com/blog/article/233323/c3932a24795b6f112cf5/

来源:python黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

13 0
收藏该文
已收藏

评论内容:(最多支持255个字符)