WordTestScreenService

public class WordTestScreenService {
WordDao wordDao = new WordDao();
BeanUtil beanUtil = new BeanUtil();
private int rightCount = 0;
private int errCount = 0;
private DecimalFormat df = new DecimalFormat("0.00");
private static Map<Integer, Integer> priorityMap = new HashMap<Integer, Integer>();
static{
priorityMap.put(1, 1);
priorityMap.put(3, 2);
priorityMap.put(6, 3);
priorityMap.put(10, 4);
priorityMap.put(15, 5);
priorityMap.put(21, 6);
priorityMap.put(28, 7);
priorityMap.put(36, 8);
priorityMap.put(45, 9);
priorityMap.put(55, 10);
priorityMap.put(66, 11);
priorityMap.put(78, 12);
priorityMap.put(91, 13);
priorityMap.put(105, 14);
priorityMap.put(120, 15);
}
public List<Word> initialTestFlag(List<Word> wordList) {
for (Word w : wordList) {
w.setFldErrorfag("2");
}
return wordList;
}


private String convertToDateFormat(String dateString) {
if (dateString.length() == 8) {
return dateString.substring(0, 4) + "-" + dateString.substring(4, 6) + "-" + dateString.substring(6, 8);
} else {
return dateString;
}
}


public String getConditionString(Map<String, Object> conditionMap) {
String coniditon = "";
int conditionCount = 0;
if (conditionMap.get("wordkey") != null) {// FLDWORDEN VARCHAR 50 No
coniditon = "word like \"" + conditionMap.get("wordkey") + "*\" \t";
conditionCount++;
}


if (conditionMap.get("ltdatestart") != null || conditionMap.get("ltdateend") != null) {
if (conditionMap.get("ltdatestart") != null && conditionMap.get("ltdateend") != null) {
coniditon += "last test date: " + convertToDateFormat(conditionMap.get("ltdatestart").toString()) + " ~ "
+ convertToDateFormat(conditionMap.get("ltdateend").toString()) + "\t";
conditionCount++;

} else if (conditionMap.get("ltdatestart") != null && conditionMap.get("ltdateend") == null) {
coniditon += "last test date >= " + convertToDateFormat(conditionMap.get("ltdatestart").toString()) + "\t";
conditionCount++;

} else if (conditionMap.get("ltdatestart") == null && conditionMap.get("ltdateend") != null) {
coniditon += "last test date <= " + convertToDateFormat(conditionMap.get("ltdateend").toString()) + "\t";
conditionCount++;

}
}
if (conditionMap.get("prioritystart") != null || conditionMap.get("priorityend") != null) { 
if (conditionMap.get("prioritystart") != null && conditionMap.get("priorityend") != null) {
coniditon += "priority: " + conditionMap.get("prioritystart") + " ~ " + conditionMap.get("priorityend") + (++conditionCount == 3?"\n":"\t");

} else if (conditionMap.get("prioritystart") != null && conditionMap.get("priorityend") == null) {
coniditon += "priority: >=" + conditionMap.get("prioritystart") + (++conditionCount == 3?"\n":"\t");

} else if (conditionMap.get("prioritystart") == null && conditionMap.get("priorityend") != null) {
coniditon += "priority: <=" + conditionMap.get("priorityend") + (++conditionCount == 3?"\n":"\t");
}
}
if (conditionMap.get("testtimesstart") != null || conditionMap.get("testtimesend") != null) {
if (conditionMap.get("testtimesstart") != null && conditionMap.get("testtimesend") != null) {
coniditon += "test times: " + conditionMap.get("testtimesstart") + " ~ " + conditionMap.get("testtimesend") + (++conditionCount == 3?"\n":"\t");
conditionCount++;

} else if (conditionMap.get("testtimesstart") != null && conditionMap.get("testtimesend") == null) {
coniditon += "test times: >=" + conditionMap.get("testtimesstart") + (++conditionCount == 3?"\n":"\t");
conditionCount++;

} else if (conditionMap.get("testtimesstart") == null && conditionMap.get("testtimesend") != null) {
coniditon += "test times: >=" + conditionMap.get("testtimesstart") + (++conditionCount == 3?"\n":"\t");
conditionCount++;
}
}
if (conditionMap.get("errortest") != null) { 
if (conditionMap.get("errortest").toString().equalsIgnoreCase("true")) {
coniditon += "the word is error" + (++conditionCount == 3?"\n":"\t");
conditionCount++;
}
}
if (conditionMap.get("showwords") != null) {
if (ReadConfig.getKey("DB_DRIVER").indexOf("mysql") >= 0) {
coniditon += "test words: " + conditionMap.get("showwords") + (++conditionCount == 3?"\n":"\t");
conditionCount++;
}
}
return coniditon;
}


public String getResult(List<Word> dataList) {
rightCount = errCount = 0;
if(dataList == null){
return "数据 为空";
}
for(Word word: dataList){
updateWord(word);
}

wordDao.updateTestWordsSalfFromCB(dataList);

String result  = "共测试" + dataList.size() + "个单词,其中正确" + rightCount + " 个,错误" + errCount + " 个,正确率 " + rightCount*1.0/dataList.size()*100.0 + ".";
return result;
}


private void updateWord(Word word) {
word.setFldLasttestdate(DateUtil.getTimeStamp().toString());// last test date
Integer priority = 0;
if(word.getFldErrorfag().equals("0")){
word.setFldTesttimes(word.getFldTesttimes()+1);
rightCount ++;
if((priority = priorityMap.get(word.getFldTesttimes())) !=null){
word.setFldPriority(priority);
}
if(word.getFldTesttimes() % 3 == 0 && word.getFldErrortimes() > 0){
word.setFldErrortimes(word.getFldErrortimes() -1);
}

}else{
errCount ++;
System.out.println(word.getFldWorden() + "," + word.getFldTesttimes());

word.setFldErrorfag("1");
word.setFldErrortimes(word.getFldErrortimes()+1);

if(word.getFldTesttimes()>0){
if((priority = priorityMap.get(word.getFldTesttimes())) !=null && word.getFldPriority() >0){
word.setFldPriority(priority-1);
}
word.setFldTesttimes(word.getFldTesttimes()-1);
}
}

}

public List<Word> randomWordList(List<Word> wordList){
Random random = new Random();
List<Word> copyWords = new ArrayList<Word>(5) ;
for(Word w:wordList){
copyWords.add(w);
}
List<Word> returnWords = new ArrayList<Word>();
for(int i = 0;i<wordList.size();i++){
int index = random.nextInt(copyWords.size());
returnWords.add(copyWords.get(index));
copyWords.remove(index);
}
return returnWords;
}


public Object[] getProgressInfo(List<Word> dataList) {
int r = 0;
int p = 0;

for(Word w:dataList){
if(w.getFldErrorfag()==null){

}else if(w.getFldErrorfag().equals("0")){
r++;
p++;
}else if(w.getFldErrorfag().equals("1")){
p++;
}
}
//"progress: 100% / right: 100%"
double progress = p*1.0/dataList.size() * 100;
double right = r*1.0 / dataList.size() * 100;
String progressInfo =  "progress:" + df.format(progress) + "% / right:" + df.format(right) + "%" ;
return new Object[]{progress,progressInfo};
}

}
使用优化算法,以优化VMD算法的惩罚因子惩罚因子 (α) 和分解层数 (K)。 1、将量子粒子群优化(QPSO)算法与变分模态分解(VMD)算法结合 VMD算法背景: VMD算法是一种自适应信号分解算法,主要用于分解信号为不同频率带宽的模态。 VMD的关键参数包括: 惩罚因子 α:控制带宽的限制。 分解层数 K:决定分解出的模态数。 QPSO算法背景: 量子粒子群优化(QPSO)是一种基于粒子群优化(PSO)的一种改进算法,通过量子行为模型增强全局搜索能力。 QPSO通过粒子的量子行为使其在搜索空间中不受位置限制,从而提高算法的收敛速度与全局优化能力。 任务: 使用QPSO优化VMD中的惩罚因子 α 和分解层数 K,以获得信号分解的最佳效果。 计划: 定义适应度函数:适应度函数根据VMD分解的效果来定义,通常使用重构信号的误差(例如均方误差、交叉熵等)来衡量分解的质量。 初始化QPSO粒子:定义粒子的位置和速度,表示 α 和 K 两个参数。初始化时需要在一个合理的范围内为每个粒子分配初始位置。 执行VMD分解:对每一组 α 和 K 参数,运行VMD算法分解信号。 更新QPSO粒子:使用QPSO算法更新粒子的状态,根据适应度函数调整粒子的搜索方向和位置。 迭代求解:重复QPSO的粒子更新步骤,直到满足终止条件(如适应度函数达到设定阈值,或最大迭代次数)。 输出优化结果:最终,QPSO算法会返回一个优化的 α 和 K,从而使VMD分解效果最佳。 2、将极光粒子(PLO)算法与变分模态分解(VMD)算法结合 PLO的优点与适用性 强大的全局搜索能力:PLO通过模拟极光粒子的运动,能够更高效地探索复杂的多峰优化问题,避免陷入局部最优。 鲁棒性强:PLO在面对高维、多模态问题时有较好的适应性,因此适合海上风电时间序列这种非线性、多噪声的数据。 应用场景:PLO适合用于优化VMD参数(α 和 K),并将其用于风电时间序列的预测任务。 进一步优化的建议 a. 实现更细致的PLO更新策略,优化极光粒子的运动模型。 b. 将PLO优化后的VMD应用于真实的海上风电数据,结合LSTM或XGBoost等模型进行风电功率预测。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值