1 /************************************************************************
2 ************************************************************************
4 Copyright (C) 2003-2004 GRAME, Centre National de Creation Musicale
5 ---------------------------------------------------------------------
6 This program 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.
11 This program 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.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 ************************************************************************
20 ************************************************************************/
27 #include "compile_scal.hh"
30 extern int gMaxCopyDelay;
33 ////////////////////////////////////////////////////////////////////////
35 * Compile a list of FAUST signals into a vector C++ class
37 ///////////////////////////////////////////////////////////////////////
39 class VectorCompiler : public ScalarCompiler
44 VectorCompiler (const string& name, const string& super, int numInputs, int numOutputs)
45 : ScalarCompiler(name,super,numInputs,numOutputs)
48 VectorCompiler (Klass* k) : ScalarCompiler(k)
50 virtual void compileMultiSignal (Tree L);
54 virtual string CS (Tree sig);
55 virtual string generateCode (Tree sig);
56 virtual void generateCodeRecursions (Tree sig);
57 virtual string generateCodeNonRec (Tree sig);
58 virtual string generateLoopCode (Tree sig);
60 virtual string generateCacheCode(Tree sig, const string& exp);
61 virtual void generateDelayLine(const string& ctype, const string& vname, int mxd, const string& exp);
62 virtual string generateVariableStore(Tree sig, const string& exp);
63 virtual string generateFixDelay (Tree sig, Tree exp, Tree delay);
64 virtual string generateDelayVec(Tree sig, const string& exp, const string& ctype, const string& vname, int mxd);
65 virtual void vectorLoop (const string& tname, const string& dlname, const string& cexp);
66 virtual void dlineLoop ( const string& tname, const string& dlname, int delay, const string& cexp);
68 bool needSeparateLoop(Tree sig);