基于Java语言开发的个性化股票分析技术:移动平均线(MA).doc_第1页
基于Java语言开发的个性化股票分析技术:移动平均线(MA).doc_第2页
基于Java语言开发的个性化股票分析技术:移动平均线(MA).doc_第3页
基于Java语言开发的个性化股票分析技术:移动平均线(MA).doc_第4页
基于Java语言开发的个性化股票分析技术:移动平均线(MA).doc_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

基于Java语言开发的个性化股票分析技术:移动平均线(MA)移动平均线(MA)是以道琼斯的“平均成本概念”为理论基础,采用移动平均的原理, 将一段时期内的股票价格平均值连成曲线,显示股价的历史波动情况,进而反映股价指数未 来发展趋势的技术分析方法。优点:显示买进和卖出信号,直观的显示价格变动大致方向。 缺点:不易把握汇价的高峰及低谷;须靠其他的技术指标的辅助。XML描述: 移动平均线(MA)是以道琼斯的“平均成本概念”为理论基础,采用移动平均的原理, 将一段时期内的股票价格平均值连成曲线,显示股价的历史波动情况,进而反映股价指数未 来发展趋势的技术分析方法。优点:显示买进和卖出信号,直观的显示价格变动大致方向。 缺点:不易把握汇价的高峰及低谷;须靠其他的技术指标的辅助。 Java代码:/* * (#)DailyMAIndicator.java * * Copyright Hangzhou Shengren Software Tech. Co., Ltd. */package com.shengrensoft.stock.model.indicator.dailyma;import java.rmi.RemoteException;import java.text.DecimalFormat;import java.util.ArrayList;import java.util.LinkedHashMap;import java.util.List;import mons.lang.math.NumberUtils;import mon.util.DateUtil;import mon.util.StkAnalysisUtil;import com.shengrensoft.stock.center.data.Data;import com.shengrensoft.stock.center.data.GettingDataList;import com.shengrensoft.stock.center.data.BlkDailyK.BlkDailyKData;import com.shengrensoft.stock.center.data.Data.DataName;import com.shengrensoft.stock.center.data.IdxDailyK.IdxDailyKData;import com.shengrensoft.stock.center.data.StkDailyK.StkDailyKData;import com.shengrensoft.stock.center.model.ModelParam;import com.shengrensoft.stock.center.model.indicator.AbstractIndicator;import com.shengrensoft.stock.center.model.indicator.IndicatorValue;/* * MA移动平均线的实现类。 * * author 迅动平台 2012/08/27 新建 */public class DailyMAIndicator extends AbstractIndicator /* 序列版本ID */ private static final long serialVersionUID = 6146654415916101973L; / 参数名定义 /* 参数名:超短期 */ private static final String PARAM_TINY = TINY; /* 参数名:短期 */ private static final String PARAM_SHRT = SHRT; /* 参数名:中期 */ private static final String PARAM_MID = MID; /* 参数名:长期 */ private static final String PARAM_LONG = LONG; /* 参数名:超长期 */ private static final String PARAM_HUGE = HUGE; / 计算值定义 /* 计算值:超短期 */ private static final String VALUE_TINY = T; /* 计算值:短期 */ private static final String VALUE_SHRT = S; /* 计算值:中期 */ private static final String VALUE_MID = M; /* 计算值:长期 */ private static final String VALUE_LONG = L; /* 计算值:超长期 */ private static final String VALUE_HUGE = H; /* * 构造方法。 */ public DailyMAIndicator() throws RemoteException /* * 计算出指定时间范围内MA移动平均线的值序列。 * * param stkCode 证券代码 * param beginDate 起始日期 * param closeDate 终止日期 * param paramsList 指标参数列表 * * return MA移动平均线的值序列 */ public LinkedHashMap calculate ( String stkCode, java.util.Date beginDate, java.util.Date closeDate, List paramsList) throws RemoteException / 如果未指定起始日期,则返回空的值序列 if (beginDate = null) return null; / 如果未指定终止日期,则以当前日期作为终止日期 if (closeDate = null) closeDate = DateUtil.getSystemTime(); / 起始日期、终止日期的前后关系检查 if (beginDate.after(closeDate) return null; / 取得指标的各个参数 int paramTINY = 0; / 参数:超短期 int paramSHRT = 0; / 参数:短期 int paramMID = 0; / 参数:中期 int paramLONG = 0; / 参数:长期 int paramHUGE = 0; / 参数:超长期 for (ModelParam param : paramsList) if (PARAM_TINY.equals(param.getShortName() paramTINY = NumberUtils.toInt(param.getValue(); else if (PARAM_SHRT.equals(param.getShortName() paramSHRT = NumberUtils.toInt(param.getValue(); else if (PARAM_MID.equals(param.getShortName() paramMID = NumberUtils.toInt(param.getValue(); else if (PARAM_LONG.equals(param.getShortName() paramLONG = NumberUtils.toInt(param.getValue(); else if (PARAM_HUGE.equals(param.getShortName() paramHUGE = NumberUtils.toInt(param.getValue(); else return null; / 发现一个意外的模型参数 / 判别证券代码类型(股票代码、股指代码、或板指代码),分别计算MA移动平均线的值序列 StkAnalysisUtil stkAnalysisUtil = super.getStkAnalysisUtil(); if (stkAnalysisUtil.isStkCode(stkCode) return this.calcStkDailyMA(stkCode, beginDate, closeDate, paramTINY, paramSHRT, paramMID, paramLONG, paramHUGE); else if (stkAnalysisUtil.isIdxCode(stkCode) return this.calcIdxDailyMA(stkCode, beginDate, closeDate, paramTINY, paramSHRT, paramMID, paramLONG, paramHUGE); else if (stkAnalysisUtil.isBlkCode(super.getUserId(), stkCode) return this.calcBlkDailyMA(stkCode, beginDate, closeDate, paramTINY, paramSHRT, paramMID, paramLONG, paramHUGE); else return null; /* * 计算出指定股票指定日期范围的MA移动平均线值序列。 * * param stkCode 股票代码 * param beginDate 起始日期 * param closeDate 终止日期 * param paramTINY 超短期参数 * param paramSHRT 短期参数 * param paramMID 中期参数 * param paramLONG 长期参数 * param paramHUGE 超长期参数 * * return MA移动平均线值序列 */ private LinkedHashMap calcStkDailyMA( String stkCode, java.util.Date beginDate, java.util.Date closeDate, int paramTINY, int paramSHRT, int paramMID, int paramLONG, int paramHUGE) / 准备好指标返回值列表 LinkedHashMap indicatorValueList = new LinkedHashMap(); / 取得指定股票指定日期范围的日K数据 GettingDataList dataList = super.getUsingDataList(); Data data = dataList.getDailyData( DataName.StkDailyKData.getShortName(), stkCode, beginDate, closeDate); if (data = null) return indicatorValueList; / 表示指定日期范围内无对应的日K数据 / 数据类型转换 StkDailyKData dailyKData = (StkDailyKData) data; / 自起始日期始至终止日期止,依次计算出各日的不同MA线的值 List tinyCloseValueList = new ArrayList(paramTINY); List shortCloseValueList = new ArrayList(paramSHRT); List middleCloseValueList = new ArrayList(paramMID); List longCloseValueList = new ArrayList(paramLONG); List hugeCloseValueList = new ArrayList(paramHUGE); / 自起始日期始至终止日期止,依次取得各日的MA移动平均线的值 java.util.Date date = beginDate; do / 日期格式转换(数据存储时统一使用了yyyyMMdd格式) String dateStr = DateUtil.getFormatedDate(date, yyyyMMdd); / 容错处理:应对因系统原因导致某日该有交易记录却没有交易记录的情况 Integer test = dailyKData.getOpen(dateStr); if (test != null & test != 0) / 构造一个值对象 IndicatorValue indicatorValue = new IndicatorValue(); Integer close = dailyKData.getClose(dateStr); if (close != null & close != 0) / 计算超短期MA值 tinyCloseValueList.add(close); / 新值加入 int num = tinyCloseValueList.size(); if (num paramTINY) tinyCloseValueList.remove(0); / 老值剔除 if (tinyCloseValueList.size() = paramTINY) String tinyMA = calcAverageValue(tinyCloseValueList); indicatorValue.setValue(VALUE_TINY,tinyMA); / 计算短期MA值 shortCloseValueList.add(close); / 新值加入 num = shortCloseValueList.size(); if (num paramSHRT) shortCloseValueList.remove(0); / 老值剔除 if (shortCloseValueList.size() = paramSHRT) String shortMA = calcAverageValue(shortCloseValueList); indicatorValue.setValue(VALUE_SHRT,shortMA); / 计算中期MA值 middleCloseValueList.add(close); / 新值加入 num = middleCloseValueList.size(); if (num paramMID) middleCloseValueList.remove(0); / 老值剔除 if (middleCloseValueList.size() = paramMID) String middleMA = calcAverageValue(middleCloseValueList); indicatorValue.setValue(VALUE_MID,middleMA); / 计算长期MA值 longCloseValueList.add(close); / 新值加入 num = longCloseValueList.size(); if (num paramLONG) longCloseValueList.remove(0); / 老值剔除 if (longCloseValueList.size() = paramLONG) String longMA = calcAverageValue(longCloseValueList); indicatorValue.setValue(VALUE_LONG,longMA); / 计算超长期MA值 hugeCloseValueList.add(close); / 新值加入 num = hugeCloseValueList.size(); if (num paramHUGE) hugeCloseValueList.remove(0); / 老值剔除 if (hugeCloseValueList.size() = paramHUGE) String hugeMA = calcAverageValue(hugeCloseValueList); indicatorValue.setValue(VALUE_HUGE,hugeMA); / 加入一个值对象 indicatorValueList.put(date,indicatorValue); / 准备取得下一日的数据 date = super.getStkTransDateUtil().getNextTransDate(stkCode,date); if (date = null) break; while (!date.after(closeDate); / 返回MA移动平均线的值序列 return indicatorValueList; /* * 计算出指定股指指定日期范围的MA移动平均线值序列。 * * param idxCode 股指代码 * param beginDate 起始日期 * param closeDate 终止日期 * param paramTINY 超短期参数 * param paramSHRT 短期参数 * param paramMID 中期参数 * param paramLONG 长期参数 * param paramHUGE 超长期参数 * * return MA移动平均线值序列 */ private LinkedHashMap calcIdxDailyMA( String idxCode, java.util.Date beginDate, java.util.Date closeDate, int paramTINY, int paramSHRT, int paramMID, int paramLONG, int paramHUGE) / 准备好指标返回值列表 LinkedHashMap indicatorValueList = new LinkedHashMap(); / 取得指定股指指定日期范围的日K数据 GettingDataList dataList = super.getUsingDataList(); Data data = dataList.getDailyData( DataName.IdxDailyKData.getShortName(), idxCode, beginDate, closeDate); if (data = null) return indicatorValueList; / 表示指定日期范围内无对应的MA移动平均线数据 / 数据类型转换 IdxDailyKData dailyKData = (IdxDailyKData) data; / 自起始日期始至终止日期止,依次计算出各日的不同MA线的值 List tinyCloseValueList = new ArrayList(paramTINY); List shortCloseValueList = new ArrayList(paramSHRT); List middleCloseValueList = new ArrayList(paramMID); List longCloseValueList = new ArrayList(paramLONG); List hugeCloseValueList = new ArrayList(paramHUGE); / 自起始日期始至终止日期止,依次取得各日的MA移动平均线的值 java.util.Date date = beginDate; do / 日期格式转换(数据存储时统一使用了yyyyMMdd格式) String dateStr = DateUtil.getFormatedDate(date, yyyyMMdd); / 容错处理:应对因系统原因导致某日该有交易记录却没有交易记录的情况 Integer test = dailyKData.getOpen(dateStr); if (test != null & test != 0) / 构造一个值对象 IndicatorValue indicatorValue = new IndicatorValue(); Integer close = dailyKData.getClose(dateStr); if(close != null & close != 0) / 计算超短期MA值 tinyCloseValueList.add(close); / 新值加入 int num = tinyCloseValueList.size(); if (num paramTINY) tinyCloseValueList.remove(0); / 老值剔除 if (tinyCloseValueList.size() = paramTINY) String tinyMA = calcAverageValue(tinyCloseValueList); indicatorValue.setValue(VALUE_TINY, tinyMA); / 计算短期MA值 shortCloseValueList.add(close); / 新值加入 num = shortCloseValueList.size(); if (num paramSHRT) shortCloseValueList.remove(0); / 老值剔除 if (shortCloseValueList.size() = paramSHRT) String shortMA = calcAverageValue(shortCloseValueList); indicatorValue.setValue(VALUE_SHRT, shortMA); / 计算中期MA值 middleCloseValueList.add(close); / 新值加入 num = middleCloseValueList.size(); if (num paramMID) middleCloseValueList.remove(0); / 老值剔除 if (middleCloseValueList.size() = paramMID) String middleMA = calcAverageValue(middleCloseValueList); indicatorValue.setValue(VALUE_MID, middleMA); / 计算长期MA值 longCloseValueList.add(close); / 新值加入 num = longCloseValueList.size(); if (num paramLONG) longCloseValueList.remove(0); / 老值剔除 if (longCloseValueList.size() = paramLONG) String longMA = calcAverageValue(longCloseValueList); indicatorValue.setValue(VALUE_LONG, longMA); / 计算超长期MA值 hugeCloseValueList.add(close); / 新值加入 num = hugeCloseValueList.size(); if (num paramHUGE) hugeCloseValueList.remove(0); / 老值剔除 if (hugeCloseValueList.size() = paramHUGE) String hugeMA = calcAverageValue(hugeCloseValueList); indicatorValue.setValue(VALUE_HUGE, hugeMA); / 加入一个值对象 indicatorValueList.put(date, indicatorValue); / 准备取得下一日的数据 date = super.getStkTransDateUtil().getNextTransDate(date); / 随大盘 if (date = null) break; while (!date.after(closeDate); / 返回MA移动平均线的值序列 return indicatorValueList; /* * 计算出指定板指指定日期范围的MA移动平均线值序列。 * * param blkCode 板指代码 * param beginDate 起始日期 * param clos

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论