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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
|
.help trebin Jul2000 tables
.nj
.ih
NAME
trebin -- Resample tables.
.ih
USAGE
trebin intable outtable column start end step
.ih
DESCRIPTION
This task resamples tables.
The grid on which to interpolate an input table
may be specified either by a table giving explicit values
or by start, end, and step values for uniform spacing.
The column names in the output table
will be the same as in the input table.
If the independent variable column ('column')
in the input table contains scalar values,
each numeric column in the input table will be rebinned
to the values of the output independent variable.
Character and boolean columns
will not be copied to the output table.
Columns that contain arrays will also not be copied to output.
On the other hand,
if the input independent variable column contains arrays
rather than scalar values,
then each row of the input table will be rebinned individually.
Scalar columns will be copied to output unchanged.
Array columns which have the same length as 'column'
will be rebinned and written to the output table;
if the array size is not the same,
the column will not be copied to output.
Except for function = "linear",
the output values are obtained by interpolation, not by fitting.
The distinction is important when rebinning to a spacing ('step')
that is significantly coarser than the spacing of the input data.
For functions other than linear,
each interpolated value is obtained as follows.
The values of the input data
nearest the current output independent variable value (X) are selected;
the input data are then interpolated at X
to obtain the value to write to the output table.
For function = "nearest", only one input point is used;
for function = "poly3" or "spline", four input points are used.
This is appropriate for rebinning
to a spacing not much different from the input data.
For resampling noisy data
to a significantly wider spacing than the input data, however,
these options will give very poor results.
In the latter case, function = "linear" (the default) should be used.
This option uses a linear fit to all the data
within an interval of width 'step' centered on each output X value.
If there are fewer than two input points in a given interval, however,
the value is interpolated the same way as is done for the other functions;
that is, the two input points nearest to X are selected,
and the value is interpolated at X
(note that these two points can be outside the 'step' interval).
A significant limitation to this task is that
there is no option to conserve total counts.
'trebin' averages the data values,
rather than summing the input bins.
What 'trebin' does is appropriate for flux-calibrated spectra,
or for time series data expressed as count rate,
but it would not be correct for data in counts,
or for count rate spectra.
.ih
PARAMETERS
.ls intable [file name template]
List of input tables to be resampled.
.le
.ls outtable [file name template]
Output tables or directory.
The number of output tables must match the number of input tables unless
'outtable' is a directory name.
.le
.ls column [string]
Name of the independent variable column in the input table,
i.e., the column on which the data are being resampled.
The same column name is used for all input tables.
The values in this column must be
either monotonically increasing or decreasing.
INDEF values and trailing 'padvalue' (described below) will be ignored.
The data type of the column is assumed to be a numeric type.
.le
.ls start [real]
If the independent variable values at which to interpolate the input values
are to be uniformly spaced,
they may be specified using 'start', 'end', and 'step'.
'start' is the first value of the output independent variable.
See also 'xtable';
'start', 'end', and 'step' will be ignored if 'xtable' was specified.
.le
.ls end [real]
Last value of the independent variable.
This may be rounded up by a fraction of 'step' to ensure that the entire
range from 'start' to 'end' is included in the output table.
.le
.ls step [real]
Increment in independent variable.
The sign of 'step' is ignored;
internally to 'trebin' the sign will be set to negative
if 'start' is larger than 'end'.
If 'start' and 'end' are the same,
the output table will contain one row,
and 'step' will only be used for the case of function = "linear".
For other values of 'function',
since the data will be interpolated at just the one point 'start',
the step size will not be needed.
.le
.ls (xtable) [file name template]
The independent variable values at which to interpolate the input values
can either be specified explicitly with 'xtable'
or computed using 'start', 'end', 'step'.
If 'xtable' is specified,
there must either be just one table name,
or the number of names must be the same as
the number of names in 'intable'.
If there is only one 'xtable',
it will be used for all input tables.
'xtable' must contain only one column.
The name of the column does not matter;
it does not need to be the same as given by 'column'.
If the actual table contains more than one column,
use the column selector syntax to specify which one to use.
The column may contain either scalar values or arrays.
If the column contains arrays,
there must be only one row;
if the actual table contains more than one row,
use the row selector syntax to specify which one to use.
The data type of the column is assumed to be a numeric type.
.le
.ls (function = "linear") [string, allowed values: nearest | linear |
poly3 | spline]
Interpolation function.
There must be at least four rows in the input table
for cubic polynomial or cubic spline interpolation.
Two rows are required for linear interpolation,
and only one for nearest-neighbor.
The "linear" option uses a linear fit,
while all other functions are interpolations
using only the required number of points
nearest the value of the independent variable.
If an input table does not contain enough rows,
or if a column being interpolated contains INDEF values
so that the total number of values is insufficient for interpolation,
the output column will be entirely INDEF;
if verbose = yes, a message will be printed.
.le
.ls (extrapolate = no) [boolean]
Extrapolate if out of bounds? See 'value' below.
.le
.ls (value = INDEF) [real]
Value to use if out of bounds.
The independent variable values
at which the input table is to be interpolated
may fall outside the range of values
in the independent variable column in the input table.
The value to write to the output table
for out of bounds independent variables depends on
the 'extrapolate' and 'value' parameters.
If 'extrapolate' is yes, then 'value' is ignored,
and the interpolation function is used for extrapolation.
If 'extrapolate' is no,
then 'value' is written to each dependent variable column
for each row that the independent variable
is outside the range of values in the input table.
Note that for columns of type integer or short,
'value' should be within the range of possible values of that type,
and if 'value' contains a fractional part
it will be rounded to the nearest integer.
.le
.ls (padvalue = INDEF) [real]
Trailing INDEF values in the independent variable column
(either in 'intable' or in 'xtable')
will be ignored.
'padvalue' can be used to specify an additional value,
such as zero,
which will also be ignored
if it occurs at the end of an array of independent variable values.
Values will be trimmed off the end of the array
until a value that is neither INDEF nor 'padvalue' is encountered.
.le
.ls (verbose = yes) [boolean]
If verbose = yes,
the input and output table names will be printed as they are processed,
and the names of columns that are not being copied to output
will also be printed.
.le
.ls (Version) [string]
This gives the date of installation of the current version.
.le
.ih
EXAMPLES
1. Resample all the columns in all tables beginning with "hr" so the values
in the "Wavelength" column range from 3000 to 8000 in steps of 10.
The output tables will have the same names, but will be written in the
directory "home$spec" (which should be different from the default directory).
.nf
tt> trebin hr*.tab "home$spec/" Wavelength 3000. 8000. 10.
.fi
2. Interpolate the text table "in" at a single point,
where the value in column one is 5,
and print the results on the standard output.
.nf
tt> trebin in STDOUT c1 5. 5. 0.
.fi
3. Interpolate the table from example 2
onto the array of independent variable values
in column "wavelength" at row 37 of "x1d.fits".
As in example 2,
the independent variable in "in" is the first column, "c1".
.nf
tt> trebin in STDOUT c1 xtable="x1d.fits[r:row=37][c:wavelength]"
.fi
.ih
BUGS
A column which contains an integer bit mask
will be interpolated as if it were an ordinary numeric column,
which is not the correct behavior.
Sometimes a table contains array columns
where the allocated array size is (or can be)
larger than the number of elements actually used.
In this case, a scalar column might be used
to specify the effective array length.
The array size in the output table
will typically be different from the array size in the input table;
'trebin' will update the allocated array size,
but it will not modify any scalar column that gives the effective array size.
.ih
REFERENCES
This task was written by Phil Hodge.
The following Numerical Recipes subroutines are used by this task:
TUCSPL, TUHUNT, TUIEP3, and TUISPL.
Numerical Recipes was written by W.H. Press, B.P. Flannery,
S.A. Teukolsky, and W.T. Vetterling.
.ih
SEE ALSO
Type "help tables opt=sys" for a higher-level description of the 'tables'
package.
.endhelp
|