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};
}

}
黑河是我国西北干旱区最重要的内陆河流之一,灌区分布及水利工程体系直接关系到流域农业发展、水资源配置与生态安全。 本资源包含黑河流域范围内的灌区空间分布矢量数据(Shapefile格式)与干支渠分布栅格图(TIF格式),可广泛应用于农业水资源管理、流域水文模拟、灌溉工程布局分析及生态水文研究等领域。 【数据内容】 灌区分布数据(Shapefile) 数据类型:矢量多边形(Polygon) 坐标系统:WGS 84 或 CGCS2000(具体可查看 .prj 文件)。 干支渠分布图(GeoTIFF) 数据类型:栅格图像(TIF) 分辨率:通常为10–30米,满足中尺度制图与分析; 图像内容:表示黑河流域干渠与支渠的空间路径分布,可作为水利网络基础图层; 内容描述:标识黑河流域主要灌区边界,包括各县(如张掖、高台、临泽、肃南等)所辖的骨干灌区、支渠灌区分布; 属性字段:灌区名称等; 应用价值:可用于构建灌溉水流路径、流量估算、水资源调度仿真模型等。 【典型应用场景】 流域灌溉调度研究:用于构建灌区供水模型,估算引水量与灌溉效率; 遥感与地理建模:与MODIS、Sentinel遥感数据叠加进行土地覆被分类或作物监测; 农业统计分析:与统计年鉴灌溉面积核对比对,服务于灌溉政策评估; 地图制图与展示:支持ArcGIS、QGIS、Mapbox等平台加载使用,可生成专题图; 水文模型输入:可作为SWAT、MIKE SHE 等模型的空间输入因子。 【附加说明】 文件命名清晰,包含 .shp, .shx, .dbf, .prj 等标准矢量格式; TIF 文件配有 .tfw 文件及标准色带,可直接叠加到DEM、水系图等背景图上; 可适配常用 GIS 软件(ArcGIS/QGIS)及建模工具; 数据来源规范,具有较高的空间精度与现势性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值