当前位置: 首页 > news >正文

有免费查企业的软件吗优化大师安卓版

有免费查企业的软件吗,优化大师安卓版,ido手表官网,山西网站建设营销什么价格一、去极值 1. MAD MAD(mean absolute deviation)又称为绝对值差中位数法,是一种先需计算所有因子与平均值之间的距离总和来检测离群值的方法. def extreme_MAD(rawdata, n): median rawdata.quantile(0.5) # 找出中位数 new_median (abs(…

一、去极值

1. MAD

MAD(mean absolute deviation)又称为绝对值差中位数法,是一种先需计算所有因子与平均值之间的距离总和来检测离群值的方法.

def extreme_MAD(rawdata, n):

    median = rawdata.quantile(0.5)  # 找出中位数

    new_median = (abs((rawdata - median)).quantile(0.5))  # 偏差值的中位数

    dt_up = median + n * new_median  # 上限

    dt_down = median - n * new_median  # 下限

    return rawdata.clip(dt_down, dt_up, axis=1)  # 超出上下限的值,赋值为上下限

data7 = filter_extreme_MAD(data6.T,7).T

print(data7)

注:根据dataframe的数据格式,看是否倒置后运算

2. 3σ

3σ法又称为标准差法。标准差本身可以体现因子的离散程度,是基于因子的平均值 Xmean而定的。

def extreme_3sigma(rawdata):

    dt_up = rawdata.mean() + 3 * rawdata.std()

    dt_down = rawdata.mean() - 3 * rawdata.std()

    rawdata = rawdata.clip(dt_down, dt_up, axis=1)

    return rawdata

data8 = extreme_3sigma(data6.T).T

print(data8)

注:根据dataframe的数据格式,看是否倒置后运算

3.  百分位法

将因子值进行升序的排序,对排位百分位高于97.5%或排位百分位低于2.5%的因子值,进行类似于 MAD 、 3σ 的方法进行调整。

def filter_extreme_percentile(series,min = 0.10,max = 0.90): #百分位法

  series = series.sort_values()

  q = series.quantile([min,max])

  return np.clip(series,q.iloc[0],q.iloc[1])

def extreme_percentile(rawdata, min=0.025, max=0.975):

    p = rawdata.quantile([min, max])  # 得到上下限的值

    return rawdata.clip(p.loc[min, :], p.loc[max, :], axis=1)
注:根据dataframe的数据格式,看是否倒置后运算

二、标准化

  1. 离差标准化(也称线性归一化)

d = (t - t.min( )) / (t.max() - t.min())

注:根据dataframe的数据格式, 看是否倒置后运算

2. 标准差标准化

 

d = (t - t.mean())/t.std()

注:根据dataframe的数据格式, 看是否倒置后运算

三、正交化

传统方法的缺陷是:如果因子间存在较强的相关性,通过上述加权方式,最终会导致因子对于某种风格的因子重复暴露。使得整个组合的表现严重偏向于该因子,削弱其他因子的效果。

正交化目的是消除因子间的相关性,并保持因子对于收益的解释度不变。

首先进行标准化,使其在同一量纲上可比。

def  orth(x):

           M = (x.shape[0] - 1) * np.cov(x.T.astype(float))  # 矩阵

            D, U = np.linalg.eig(M)  # 获取特征值和特征向量

            U = np.mat(U)  # 转换为np中的矩阵

            d = np.mat(np.diag(D ** (-0.5)))  # 对特征根元素开(-0.5)指数

            S = U * d * U.T  # 获取过渡矩阵S

            factors_orthogonal_mat = np.mat(x) * S  # 获取对称正交矩阵

            x = pd.DataFrame(factors_orthogonal_mat, columns=x.columns, index=x.index)

     return x

使用截面数据,使用完后检验其相关性是否变小

rawdata.corr()

orth(x).corr()

四、中性化

 传统方法的缺陷是对于因子暴露在不同行业、市值上的分布不均匀,比如在小市值医药股上数值偏高,其他偏低,导致可比性下降。

如果是基本面分析需要针对不同的行业进行对比,而中性化直接通过回归取残差来避免类似问题。

中性化的方式是对因子暴露值和市值、行业做线性回归,最后用剩下的残差替代因子值。这个残差肯定是跟市值和行业无关的。

(1)为股票池添加上行业标记,0、1标记

        dummy = pd.read_csv('industry_dummy.csv', index_col=0)

import numpy as np

import pandas as pd

import math

from statsmodels import regression

import statsmodels.api as sm

#factor: 以code为index, 因子值为value的series

y = factors

#市值中性化

#mkt_ca: 以股票为index, 市值为value的series

x = mkt_cap.apply(lambda x:math.log(x))

#行业中性化

x = dummy

result = sm.OLS(y.astype(float),x.astype(float)).fit()

output = result.resid

 

http://www.tj-hxxt.cn/news/52315.html

相关文章:

  • 网站怎么做域名实名认证草根站长工具
  • 全球速卖通官网入口网站优化推广费用
  • 网站建设犀牛云怎样弄一个自己的平台
  • 商标logo免费设计在线生成seo技术建站
  • 网站地图好处seo排名计费系统
  • 做坑人网站二维码怎样免费推广自己的网站
  • 深圳大公司西安关键词seo
  • 山东个人网站备案域名收录提交入口
  • 最好的微网站建设价格seo是一种利用搜索引擎
  • 深圳专业网站建设要求网站seo方案撰写
  • 我要设计网关键词优化推广公司排名
  • 个体工商户备案网站备案网站seo收录
  • 贵阳网站备案网络营销有哪些就业岗位
  • 打开网站是iis7seo推广案例
  • 吉安网站建设兼职郑州网站建设外包
  • 网站默认数据库地址搜索引擎营销特点
  • 网站的流量怎么赚钱域名站长工具
  • 哪些网站是python做的2345网址导航是什么浏览器
  • ps怎么排版规划设计网站免费seo优化
  • 网站模拟课堂模式应该怎么做天津seo管理平台
  • 郑州橱柜网站建设深圳seo关键词优化外包公司
  • 镇江网站建设远航网络seo对网络推广的作用是
  • 做网站发布信息厦门seo蜘蛛屯
  • 文案类的网站友情链接获取的途径有哪些
  • ps做图软件怎么下载网站优化20条措施
  • 苏州优化网站建设产品如何做市场推广
  • 网站怎么做优化排名靠前东莞网站优化公司
  • php如何做视频网站北京优化网站推广
  • 辽宁省建设执业继续教育协会网站网站优化方式有哪些
  • 找做仿网站游戏代理0加盟费