Add File
This commit is contained in:
106
src/main/java/org/dromara/easyai/tools/GMClustering.java
Normal file
106
src/main/java/org/dromara/easyai/tools/GMClustering.java
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
package org.dromara.easyai.tools;
|
||||||
|
|
||||||
|
import org.dromara.easyai.matrixTools.Matrix;
|
||||||
|
import org.dromara.easyai.entity.RGBNorm;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param
|
||||||
|
* @DATA
|
||||||
|
* @Author LiDaPeng
|
||||||
|
* @Description
|
||||||
|
*/
|
||||||
|
public class GMClustering extends MeanClustering {
|
||||||
|
private float regionSize;//单区域面积
|
||||||
|
|
||||||
|
public float getRegionSize() {
|
||||||
|
return regionSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setRegionSize(float regionSize) {
|
||||||
|
this.regionSize = regionSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GMClustering(int speciesQuantity, int maxTimes) throws Exception {
|
||||||
|
super(speciesQuantity, maxTimes);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getProbabilityDensity(float[] feature) throws Exception {//获取簇id
|
||||||
|
float maxPower = 0;
|
||||||
|
int id = 0;
|
||||||
|
int index = 0;
|
||||||
|
for (RGBNorm rgbNorm : matrices) {
|
||||||
|
float power = rgbNorm.getGMProbability(feature);
|
||||||
|
if (power > maxPower) {
|
||||||
|
maxPower = power;
|
||||||
|
id = index;
|
||||||
|
}
|
||||||
|
index++;
|
||||||
|
}
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void start() throws Exception {
|
||||||
|
super.start();
|
||||||
|
for (RGBNorm rgbNorm : matrices) {//高斯系数初始化
|
||||||
|
rgbNorm.gm();
|
||||||
|
}
|
||||||
|
for (int i = 0; i < 50; i++) {
|
||||||
|
gmClustering();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void insertParameter(Matrix matrix) throws Exception {
|
||||||
|
int y = matrix.getY();
|
||||||
|
int size = y / speciesQuantity;
|
||||||
|
for (int i = 0; i <= y - size; i += size) {
|
||||||
|
float[] feature = new float[size];
|
||||||
|
RGBNorm rgbNorm = new RGBNorm();
|
||||||
|
matrices.add(rgbNorm);
|
||||||
|
for (int j = i; j < i + size; j++) {
|
||||||
|
feature[j - i] = matrix.getNumber(0, j);
|
||||||
|
}
|
||||||
|
rgbNorm.insertFeature(feature);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void clear() {
|
||||||
|
for (RGBNorm rgbNorm : matrices) {//高斯系数初始化
|
||||||
|
rgbNorm.clearRGB();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void gmClustering() throws Exception {//进行gm聚类
|
||||||
|
clear();
|
||||||
|
for (float[] rgb : matrixList) {//遍历当前集合
|
||||||
|
float allProbability = 0;//全概率
|
||||||
|
float[] pro = new float[speciesQuantity];
|
||||||
|
for (int i = 0; i < speciesQuantity; i++) {
|
||||||
|
RGBNorm rgbNorm = matrices.get(i);
|
||||||
|
float probability = rgbNorm.getGMProbability(rgb);
|
||||||
|
//System.out.println("pro===" + probability);
|
||||||
|
allProbability = allProbability + probability;
|
||||||
|
pro[i] = probability;
|
||||||
|
}
|
||||||
|
//求每个簇的后验概率
|
||||||
|
for (int i = 0; i < speciesQuantity; i++) {
|
||||||
|
pro[i] = pro[i] / allProbability;
|
||||||
|
}
|
||||||
|
//判断概率最大的簇
|
||||||
|
int index = 0;
|
||||||
|
float max = 0;
|
||||||
|
for (int i = 0; i < speciesQuantity; i++) {
|
||||||
|
if (pro[i] > max) {
|
||||||
|
max = pro[i];
|
||||||
|
index = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//注入特征
|
||||||
|
matrices.get(index).setGmFeature(rgb, pro[index]);
|
||||||
|
}
|
||||||
|
for (RGBNorm rgbNorm : matrices) {//高斯系数初始化
|
||||||
|
rgbNorm.gm();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user