source: trunk/src/SDTemplates.cc@ 398

Last change on this file since 398 was 383, checked in by mar637, 20 years ago

added template for Vector<Int>(vector<int>)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.7 KB
Line 
1//#---------------------------------------------------------------------------
2//# SDTemplates.cc: explicit templates for aips++
3//#---------------------------------------------------------------------------
4//# Copyright (C) 2004
5//# ATNF
6//#
7//# This program is free software; you can redistribute it and/or modify it
8//# under the terms of the GNU General Public License as published by the Free
9//# Software Foundation; either version 2 of the License, or (at your option)
10//# any later version.
11//#
12//# This program is distributed in the hope that it will be useful, but
13//# WITHOUT ANY WARRANTY; without even the implied warranty of
14//# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
15//# Public License for more details.
16//#
17//# You should have received a copy of the GNU General Public License along
18//# with this program; if not, write to the Free Software Foundation, Inc.,
19//# 675 Massachusetts Ave, Cambridge, MA 02139, USA.
20//#
21//# Correspondence concerning this software should be addressed as follows:
22//# Internet email: Malte.Marquarding@csiro.au
23//# Postal address: Malte Marquarding,
24//# Australia Telescope National Facility,
25//# P.O. Box 76,
26//# Epping, NSW, 2121,
27//# AUSTRALIA
28//#
29//# $Id:
30//#---------------------------------------------------------------------------
31#include "SDMemTable.h"
32
33#include <casa/aips.h>
34#include <casa/namespace.h>
35#include <casa/Containers/Block.h>
36#include <casa/Exceptions/Error.cc>
37#include <casa/Exceptions/Error2.cc>
38#include <casa/Utilities/CountedPtr.cc>
39#include <casa/Utilities/CountedPtr2.cc>
40#include <casa/Utilities/Copy.cc>
41
42namespace asap {
43 template class casa::CountedConstPtr<SDMemTable>;
44 template class casa::CountedPtr<SDMemTable>;
45 template class casa::PtrRep<SDMemTable>;
46 template class casa::SimpleCountedConstPtr<SDMemTable>;
47 template class casa::SimpleCountedPtr<SDMemTable>;
48 template class casa::Block<CountedPtr<SDMemTable> >;
49}
50
51template void objcopy<CountedPtr<asap::SDMemTable> >(CountedPtr<asap::SDMemTable> *, CountedPtr<asap::SDMemTable> const *, uInt);
52template void objmove<CountedPtr<asap::SDMemTable> >(CountedPtr<asap::SDMemTable> *, CountedPtr<asap::SDMemTable> const *, uInt);
53template void objset<CountedPtr<asap::SDMemTable> >(CountedPtr<asap::SDMemTable> *, CountedPtr<asap::SDMemTable>, uInt);
54
55#include <casa/Arrays/ArrayLogical.cc>
56#include <casa/Arrays/ArrayMath.cc>
57#include <casa/Arrays/MaskArrMath.cc>
58#include <casa/Arrays/Array.h>
59#include <casa/Arrays/Vector.h>
60#include <casa/Arrays/Vector2.cc>
61#include <casa/Utilities/PtrHolder.cc>
62#include <casa/Utilities/BinarySearch.cc>
63#include <coordinates/Coordinates/VelocityAligner.cc>
64#include <coordinates/Coordinates/FrequencyAligner.cc>
65#include <lattices/Lattices/Lattice.h>
66#include <lattices/Lattices/LatticeUtilities.cc>
67#include <scimath/Functionals/CompiledFunction.cc>
68#include <scimath/Functionals/CompiledParam.cc>
69#include <scimath/Mathematics/AutoDiff.h>
70#include <scimath/Mathematics/AutoDiffMath.h>
71#include <scimath/Mathematics/InterpolateArray1D.cc>
72
73template void convertArray<Bool, uChar>(Array<Bool> &, Array<uChar> const &);
74template void convertArray<uChar, Bool>(Array<uChar> &, Array<Bool> const &);
75template LogicalArray operator!=<Float>(Array<Float> const &, Float const &);
76template LogicalArray operator==<Float>(Array<Float> const &, Float const &);
77template LogicalArray operator><Float>(Array<Float> const &, Float const &);
78template LogicalArray operator>=<Float>(Array<Float> const &, Float const &);
79template Array<Float>& operator/=<Float>(Array<Float>&, MaskedArray<Float> const&);
80template MaskedArray<Float> const& operator*=<Float>(MaskedArray<Float> const&, Float const&);
81template MaskedArray<Float> operator+<Float>(MaskedArray<Float> const&, MaskedArray<Float> const&);
82template MaskedArray<Float> operator-<Float>(MaskedArray<Float> const&, MaskedArray<Float> const&);
83template MaskedArray<Float> operator*<Float>(MaskedArray<Float> const&, MaskedArray<Float> const&);
84template MaskedArray<Float> operator/<Float>(MaskedArray<Float> const&, MaskedArray<Float> const&);
85template MaskedArray<Float> const& operator/=<Float>(MaskedArray<Float> const&, Float const&);
86template MaskedArray<Float> operator-<Float>(MaskedArray<Float> const&, Array<Float> const&);
87template MaskedArray<Float> operator*<Float>(Array<Float> const&, MaskedArray<Float> const&);
88template Float stddev<Float>(MaskedArray<Float> const&);
89template Float median<Float>(MaskedArray<Float> const&);
90template Float sumsquares<Float>(MaskedArray<Float> const&);
91template Float avdev<Float>(MaskedArray<Float> const&);
92template class CompiledFunction<AutoDiff<Float> >;
93template class CompiledParam<AutoDiff<Float> >;
94template Vector<Bool>::Vector(const vector<bool> &);
95template Vector<Int>::Vector(const vector<int> &);
96template Vector<Float>::Vector(const vector<float> &);
97template Vector<Double>::Vector(const vector<double> &);
98template void Array<float>::tovector(vector<float> &) const;
99template void Array<Bool>::tovector(vector<bool> &) const;
100template void Array<double>::tovector(vector<double> &) const;
101template void LatticeUtilities::bin(MaskedArray<float>&, MaskedArray<float> const&, uInt, uInt);
102template class PtrHolder<Lattice<Float> >;
103template class VelocityAligner<Float>;
104template class FrequencyAligner<Float>;
105template class InterpolateArray1D<Double, Float>;
106template Int binarySearchBrackets<Vector<Double>,Double>(Bool &, Vector<Double> const &, Double const &, uInt, Int);
107//
108#include "MathUtils2.cc"
109namespace mathutil {
110 template void hanning(Vector<Float>&, Vector<Bool>&,
111 const Vector<Float>&,
112 const Vector<Bool>&,
113 Bool, Bool);
114 template uInt addEntry(Vector<uInt>&, uInt);
115}
Note: See TracBrowser for help on using the repository browser.