Project

General

Profile

Download (4.12 KB) Statistics
| Branch: | Revision:

library / src / main / java / org / distorted / library / type / Static1D.java @ bff329fb

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2016 Leszek Koltunski                                                               //
3
//                                                                                               //
4
// This file is part of Distorted.                                                               //
5
//                                                                                               //
6
// Distorted is free software: you can redistribute it and/or modify                             //
7
// it under the terms of the GNU General Public License as published by                          //
8
// the Free Software Foundation, either version 2 of the License, or                             //
9
// (at your option) any later version.                                                           //
10
//                                                                                               //
11
// Distorted is distributed in the hope that it will be useful,                                  //
12
// but WITHOUT ANY WARRANTY; without even the implied warranty of                                //
13
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                 //
14
// GNU General Public License for more details.                                                  //
15
//                                                                                               //
16
// You should have received a copy of the GNU General Public License                             //
17
// along with Distorted.  If not, see <http://www.gnu.org/licenses/>.                            //
18
///////////////////////////////////////////////////////////////////////////////////////////////////
19

    
20
package org.distorted.library.type;
21

    
22
///////////////////////////////////////////////////////////////////////////////////////////////////
23
/**
24
 * A 1-dimensional data structure containing a single float. The float has no particular meaning; 
25
 * when this data structure is used in Dynamics, we can think of it as a 1-dimensional Point
26
 * a few of which the Dynamic interpolates between.
27
 */
28

    
29
public class Static1D extends Static implements Data1D
30
  {
31
  float x;
32

    
33
///////////////////////////////////////////////////////////////////////////////////////////////////
34
/**
35
 * Constructor that initialises the value of the single float to ox.   
36
 *   
37
 * @param ox value of the single float.
38
 */  
39
  public Static1D(float ox)
40
    {
41
    super(1);
42
    x = ox;
43
    }
44

    
45
///////////////////////////////////////////////////////////////////////////////////////////////////
46
/**
47
 * Copy constructor.
48
 */
49
  public Static1D(Static1D sta)
50
    {
51
    super(1);
52
    x = sta.x;
53
    }
54

    
55
///////////////////////////////////////////////////////////////////////////////////////////////////
56
/**
57
 * Resets the value of the single float.
58
 * 
59
 * @param ox new value of the single float.
60
 */
61
  public void set(float ox)
62
    {
63
    x = ox;
64
    }
65

    
66
///////////////////////////////////////////////////////////////////////////////////////////////////
67
/**
68
 * Copy a Static1D.
69
 */
70
  public void set(Static1D s)
71
    {
72
    x = s.x;
73
    }
74

    
75
///////////////////////////////////////////////////////////////////////////////////////////////////
76
/**
77
 * Resets the value of the first float.
78
 *
79
 * @param ox new value of the first float.
80
 */
81
  public void set0(float ox)
82
    {
83
    x = ox;
84
    }
85

    
86
///////////////////////////////////////////////////////////////////////////////////////////////////
87
/**
88
 * Return the value of the float contained.
89
 * 
90
 * @return The single float.
91
 */
92
  public float get0()
93
    {
94
    return x;  
95
    }
96

    
97
///////////////////////////////////////////////////////////////////////////////////////////////////
98
/**
99
 * 'Interpolation' between the single Point (i.e. always this very value) returned to the buffer.
100
 *
101
 * @param buffer Float buffer we will write the results to.
102
 * @param offset Offset in the buffer where to write the result.
103
 * @param time not used
104
 * @param step not used
105
 * @return <code>false</code>
106
 */
107
  public boolean get(float[] buffer, int offset, long time, long step)
108
    {
109
    buffer[offset] = x;
110
    return false;
111
    }
112
  }
(14-14/18)