====== Parameterized design using templates ======
Template provides a good way to create a parameterized design framework which can be used to get customized design from a generic design based on user input. ACT supports templates to create parameterized types, channel, and processes.
Let’s revisit the ripple carry adder designed in previous example. Instead of designing adder with fixed bit-width, a generic N-bit adder can be created using ''template'' keyword as shown below:
import "adder.act";
template
defproc adderNb (bool? a[N],b[N],ci; bool! s[N],co)
{
bool c[N+1];
fulladder fa[N];
c[0] = ci;
co = c[N];
( i : N : fa[i](a[i], b[i], c[i], s[i], c[i+1]);)
}
This example imports ''adder.act'' which contains full adder and generates a ripple carry adder using loop. Note that parameter ''N'' is used here to specify bit-width of the adder.
As shown below, an arbitrary bit-width adder can be created by instantiating the process ''adderNb'' with different values of parameter ''N''.
adderNb<8> fa8;
This creates an 8-bit adder with instance name ''fa8''. Similarly, a 32-bit adder could be created by instantiating adder with parameter N = 32.