~seh999/jcog/proto3

« back to all changes in this revision

Viewing changes to spacetime/src.tool/opencog/spacetime/toolsystem/virtual/VirtualProductMatrix.java

  • Committer: SeH
  • Date: 2009-09-19 22:59:48 UTC
  • Revision ID: seh999@gmail.com-20090919225948-q3ab80xa57i74mm6
start of major jReality refactoring

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/**
2
 
 *
3
 
 * This file is part of jReality. jReality is open source software, made
4
 
 * available under a BSD license:
5
 
 *
6
 
 * Copyright (c) 2003-2006, jReality Group: Charles Gunn, Tim Hoffmann, Markus
7
 
 * Schmies, Steffen Weissmann.
8
 
 *
9
 
 * All rights reserved.
10
 
 *
11
 
 * Redistribution and use in source and binary forms, with or without
12
 
 * modification, are permitted provided that the following conditions are met:
13
 
 *
14
 
 * - Redistributions of source code must retain the above copyright notice, this
15
 
 *   list of conditions and the following disclaimer.
16
 
 *
17
 
 * - Redistributions in binary form must reproduce the above copyright notice,
18
 
 *   this list of conditions and the following disclaimer in the documentation
19
 
 *   and/or other materials provided with the distribution.
20
 
 *
21
 
 * - Neither the name of jReality nor the names of its contributors nor the
22
 
 *   names of their associated organizations may be used to endorse or promote
23
 
 *   products derived from this software without specific prior written
24
 
 *   permission.
25
 
 *
26
 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
27
 
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28
 
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
29
 
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
30
 
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31
 
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32
 
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33
 
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34
 
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35
 
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36
 
 * POSSIBILITY OF SUCH DAMAGE.
37
 
 *
38
 
 */
39
 
 
40
 
 
41
 
package opencog.spacetime.toolsystem.virtual;
42
 
 
43
 
import java.util.List;
44
 
import java.util.Map;
45
 
 
46
 
import opencog.spacetime.math.Rn;
47
 
import opencog.spacetime.scene.data.DoubleArray;
48
 
import opencog.spacetime.scene.tool.InputSlot;
49
 
import opencog.spacetime.toolsystem.MissingSlotException;
50
 
import opencog.spacetime.toolsystem.ToolEvent;
51
 
import opencog.spacetime.toolsystem.VirtualDevice;
52
 
import opencog.spacetime.toolsystem.VirtualDeviceContext;
53
 
 
54
 
 
55
 
 
56
 
/**
57
 
 *
58
 
 * TODO: comment this
59
 
 *
60
 
 * @author weissman
61
 
 *
62
 
 */
63
 
public class VirtualProductMatrix implements VirtualDevice {
64
 
 
65
 
  InputSlot leftSlot, rightSlot;
66
 
  InputSlot productSlot;
67
 
  double[] product = new double[16];
68
 
  
69
 
  double[] matrixL = new double[16];
70
 
  double[] matrixR = new double[16];
71
 
  
72
 
  public ToolEvent process(VirtualDeviceContext context) throws MissingSlotException {
73
 
    try {
74
 
      DoubleArray matrixLeft = context.getTransformationMatrix(leftSlot);
75
 
      matrixL = matrixLeft.toDoubleArray(matrixL);
76
 
    } catch (NullPointerException npe) {
77
 
      throw new MissingSlotException(leftSlot);
78
 
    }
79
 
    try {
80
 
    DoubleArray matrixRight = context.getTransformationMatrix(rightSlot);
81
 
      matrixR = matrixRight.toDoubleArray(matrixR);
82
 
    } catch (NullPointerException npe) {
83
 
      throw new MissingSlotException(rightSlot);
84
 
    }
85
 
      product = Rn.times(product, matrixL, matrixR);
86
 
      return new ToolEvent(context.getEvent().getSource(), context.getEvent().getTimeStamp(), productSlot, new DoubleArray(product));
87
 
  }
88
 
 
89
 
  public void initialize(List inputSlots, InputSlot result, Map configuration) {
90
 
    productSlot = result;
91
 
    leftSlot = (InputSlot) inputSlots.get(0);
92
 
    rightSlot = (InputSlot) inputSlots.get(1);
93
 
  }
94
 
 
95
 
  public void dispose() {
96
 
  }
97
 
 
98
 
  public String getName() {
99
 
    return "ProductMatrix";
100
 
  }
101
 
 
102
 
  public String toString() {
103
 
    return "VirtualDevice: "+getName();
104
 
  }
105
 
}