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.openimaj.citation.annotation.Reference;
33 import org.openimaj.citation.annotation.ReferenceType;
34 import org.openimaj.feature.DoubleFV;
35 import org.openimaj.feature.FeatureVectorProvider;
36 import org.openimaj.image.FImage;
37 import org.openimaj.image.MBFImage;
38 import org.openimaj.image.analyser.ImageAnalyser;
39 import org.openimaj.image.mask.AbstractMaskedObject;
40
41
42
43
44
45
46
47 @Reference(
48 type = ReferenceType.Inproceedings,
49 author = { "Jose San Pedro", "Stefan Siersdorfer" },
50 title = "Ranking and Classifying Attractiveness of Photos in Folksonomies",
51 year = "2009",
52 booktitle = "18th International World Wide Web Conference",
53 pages = { "771", "", "771" },
54 url = "http://www2009.eprints.org/78/",
55 month = "April")
56 public class Saturation extends AbstractMaskedObject<FImage>
57 implements
58 ImageAnalyser<MBFImage>,
59 FeatureVectorProvider<DoubleFV>
60 {
61 double saturation;
62
63 @Override
64 public DoubleFV getFeatureVector() {
65 return new DoubleFV(new double[] { saturation });
66 }
67
68 @Override
69 public void analyseImage(MBFImage image) {
70 final FImage R = image.getBand(0);
71 final FImage G = image.getBand(1);
72 final FImage B = image.getBand(2);
73
74 int N = 0;
75 double sat = 0;
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 sat += (max - min);
84 N++;
85 }
86 }
87 }
88 } else {
89 for (int y = 0; y < R.height; y++) {
90 for (int x = 0; x < R.width; x++) {
91 final float min = Math.min(Math.min(R.pixels[y][x], G.pixels[y][x]), B.pixels[y][x]);
92 final float max = Math.max(Math.max(R.pixels[y][x], G.pixels[y][x]), B.pixels[y][x]);
93 sat += (max - min);
94 N++;
95 }
96 }
97 }
98
99 saturation = sat / N;
100 }
101
102
103
104
105
106
107
108 public double getSaturation() {
109 return saturation;
110 }
111 }