All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.maizegenetics.analysis.numericaltransform.ImputationByMean Maven / Gradle / Ivy

package net.maizegenetics.analysis.numericaltransform;

/**
 * Imputation of the missing data by mean of the respective column.
 *
 * @author Janu Verma
 *
 */
public class ImputationByMean {

    private ImputationByMean() {
        // utility class
    }

    /**
     * Impute the missing values.
     *
     * @param data matrix
     * @return imputed data
     */
    public static double[][] impute(double[][] data) {
        int rows = data.length;
        int cols = data[0].length;
        //double[][] normData = Conversion.nomalizeData(data);
        double[][] result = new double[rows][cols];
        for (int j = 0; j < cols; j++) {
        	double colmean = mean(j, data);
        	for (int i = 0; i < rows; i++) {
        		if (!Double.isNaN(data[i][j])) {
        			result[i][j] = data[i][j];
        		} else {
        			result[i][j] = colmean;
        		}
        	}
        }
        
        return result;
    }

    /**
     *
     * @param col containing the missing data point.
     * @param data matrix
     * @return mean of the column.
     */
    public static double mean(int col, double[][] data) {
        int rows = data.length;
        double average;
        double sum = 0;
        double count = 0;
        for (int i = 0; i < rows; i++) {
            if (!Double.isNaN(data[i][col])) {
                sum += data[i][col];
                count++;
            }
        }
        average = sum / count;
        return average;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy