1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30 package org.openimaj.image.feature.global;
31
32 import org.apache.commons.math.stat.descriptive.SummaryStatistics;
33 import org.openimaj.citation.annotation.Reference;
34 import org.openimaj.citation.annotation.ReferenceType;
35 import org.openimaj.feature.DoubleFV;
36 import org.openimaj.feature.FeatureVectorProvider;
37 import org.openimaj.image.FImage;
38 import org.openimaj.image.MBFImage;
39 import org.openimaj.image.analyser.ImageAnalyser;
40 import org.openimaj.image.mask.AbstractMaskedObject;
41
42
43
44
45
46
47
48 @Reference(
49 type = ReferenceType.Inproceedings,
50 author = { "Jose San Pedro", "Stefan Siersdorfer" },
51 title = "Ranking and Classifying Attractiveness of Photos in Folksonomies",
52 year = "2009",
53 booktitle = "18th International World Wide Web Conference",
54 pages = { "771", "", "771" },
55 url = "http://www2009.eprints.org/78/",
56 month = "April")
57 public class SaturationVariation extends AbstractMaskedObject<FImage>
58 implements
59 ImageAnalyser<MBFImage>,
60 FeatureVectorProvider<DoubleFV>
61 {
62 double saturationVariation;
63
64 @Override
65 public DoubleFV getFeatureVector() {
66 return new DoubleFV(new double[] { saturationVariation });
67 }
68
69 @Override
70 public void analyseImage(MBFImage image) {
71 final FImage R = image.getBand(0);
72 final FImage G = image.getBand(1);
73 final FImage B = image.getBand(2);
74
75 final SummaryStatistics stats = new SummaryStatistics();
76
77 if (mask != null) {
78 for (int y = 0; y < R.height; y++) {
79 for (int x = 0; x < R.width; x++) {
80 if (mask.pixels[y][x] == 1) {
81 final float min = Math.min(Math.min(R.pixels[y][x], G.pixels[y][x]), B.pixels[y][x]);
82 final float max = Math.max(Math.max(R.pixels[y][x], G.pixels[y][x]), B.pixels[y][x]);
83 stats.addValue(max - min);
84 }
85 }
86 }
87 } else {
88 for (int y = 0; y < R.height; y++) {
89 for (int x = 0; x < R.width; x++) {
90 final float min = Math.min(Math.min(R.pixels[y][x], G.pixels[y][x]), B.pixels[y][x]);
91 final float max = Math.max(Math.max(R.pixels[y][x], G.pixels[y][x]), B.pixels[y][x]);
92 stats.addValue(max - min);
93 }
94 }
95 }
96
97 saturationVariation = stats.getStandardDeviation();
98 }
99
100
101
102
103
104
105
106 public double getSaturationVariation() {
107 return saturationVariation;
108 }
109 }