Statistics
| Revision:

svn-gvsig-desktop / branches / org.gvsig.desktop-2018a / org.gvsig.desktop.library / org.gvsig.raster / org.gvsig.raster.lib / org.gvsig.raster.lib.buffer.api / src / main / java / org / gvsig / raster / lib / buffer / api / statistics / HistogramBand.java @ 43803

History | View | Annotate | Download (3.99 KB)

1
/* gvSIG. Desktop Geographic Information System.
2
 *
3
 * Copyright ? 2007-2016 gvSIG Association
4
 *
5
 * This program is free software; you can redistribute it and/or
6
 * modify it under the terms of the GNU General Public License
7
 * as published by the Free Software Foundation; either version 2
8
 * of the License, or (at your option) any later version.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with this program; if not, write to the Free Software
17
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
18
 * MA  02110-1301, USA.
19
 *
20
 * For any additional information, do not hesitate to contact us
21
 * at info AT gvsig.com, or visit our website www.gvsig.com.
22
 */
23
package org.gvsig.raster.lib.buffer.api.statistics;
24

    
25
/**
26
 * @author fdiaz
27
 *
28
 */
29
public interface HistogramBand {
30

    
31
    /**
32
     * Obtiene n?mero de valores
33
     *
34
     * @return entero con el n?mero de valores del histograma
35
     */
36
    public long getNumValues();
37

    
38
    /**
39
     * Obtiene el tipo de datos de la banda
40
     *
41
     * @return el tipo de datos de la banda
42
     */
43
    public int getDataType();
44

    
45
    // /**
46
    // * Obtiene un valor del histograma segun la posicion dentro de las clases
47
    // * @param pos Pixel o valor de la clase del valor a recuperar
48
    // *
49
    // * @return valor
50
    // */
51
    // public long getHistogramValueByPos(int pos);
52

    
53
    /**
54
     * Obtiene un valor del histograma
55
     *
56
     * @param value
57
     *            valor de la clase a recuperar
58
     * @return valor
59
     */
60
    public long getHistogramValue(double value);
61

    
62
    /**
63
     * Realiza la uni?n entre el histograma actual y el pasado
64
     * por par?metro.
65
     *
66
     * @param hist
67
     * @return true if the union has been possible
68
     */
69
    public boolean union(HistogramBand hist);
70

    
71
    /**
72
     * Obtiene los valores de las clases
73
     *
74
     * @return los valores de las clases
75
     */
76
    public long[] getFrequencies();
77

    
78
    /**
79
     * Obtiene el n?mero de clases del histograma
80
     *
81
     * @return entero que representa el n?mero de valores o clases del
82
     *         histograma
83
     */
84
    public int getNumClasses();
85

    
86
    /**
87
     * Devuelve el n?mero de valores de un intervalo
88
     *
89
     * @param interval
90
     * @return el n?mero de valores del intervalo
91
     */
92
    public long getValueCount(int interval);
93

    
94
    /**
95
     * Devuelve el valor m?nimo de un intervalo
96
     *
97
     * @param interval
98
     * @return el valor m?nimo del intervalo
99
     */
100
    public double getIntervalMin(int interval);
101

    
102
    /**
103
     * Devuelve el valor m?ximo de un intervalo
104
     *
105
     * @param interval
106
     * @return el valor m?ximo del intervalo
107
     */
108
    public double getIntervalMax(int interval);
109

    
110
    /**
111
     * @return median value
112
     */
113
    public double getMedian();
114

    
115
    /**
116
     * Obtiene un valor de recorte de colas para un porcentaje dado. Este
117
     * recorte consiste en ordenar los elementos del
118
     * raster (o una muestra de ellos) y devolver el valor que corresponde al
119
     * porcentaje comenzando
120
     * desde el principio del array ordenado y desde el final de ?l (m?nimo y
121
     * m?ximo).
122
     *
123
     * @param percent
124
     *            Porcentaje de recorte
125
     * @return El valor de recorte de colas para el porcentaje dado
126
     */
127
    public double[] getTailTrimValue(double percent);
128

    
129
    /**
130
     * Obtiene un valor de recorte de colas para una posici?n dada. Este recorte
131
     * consiste en ordenar los elementos del
132
     * raster (o una muestra de ellos) y devolver el valor que corresponde al
133
     * porcentaje comenzando
134
     * desde el principio del array ordenado y desde el final de ?l (m?nimo y
135
     * m?ximo).
136
     *
137
     * @param pos
138
     *            posici?n de recorte
139
     * @return el valor de recorte de colas para la posici?n dada
140
     */
141
    public double[] getTailTrimValue(int pos);
142
}