Header Ads

Header ADS

Program for Convolution

Introduction

Hello friends, In this post, we will learn how to write a simple program in C for convolution.
This tutorial is for those people who want to learn programming in C and do not necessarily have any previous knowledge of other programming languages. Of course any knowledge of other programming languages or any general computer skill can be useful to better understand this tutorial, although it is not essential.
Here we are calling two standard library functions. Whenever we call the library functions we must write their prototype before making the call.This helps the compiler in checking whether the values being passed and returned are as per the prototype declaration.But since we don’t define the library functions (we merely call them) we may not know the prototypes of library functions. Hence when the library of functions is provided a set of ‘.h’ files is also provided.These files contain the prototypes of library functions. But why multiple files? Because the library functions are divided into different groups and one file is provided for each group. For example, prototypes of all input/output functions are provided in the file ‘stdio.h’, prototypes of all mathematical functions are provided in the file ‘math.h’, etc.
On compilation of the above code the compiler reports all errors due to the mismatch between parameters in function call and their corresponding prototypes declared in the file ‘conio.h’. You can even open this file and look at the prototypes.

Program Briefing

First, we call the standard library function 'stdio.h' because prototypes of all input/output functions are provided in the file ‘stdio.h’. Then we call the standard library function 'conio.h' because On compilation of the above code the compiler reports all errors due to the mismatch between parameters in function call and their corresponding prototypes declared in the file ‘conio.h’. Then comes the program's main body. We declare three integer arrays x,h and ans. And one two dimensional array 'h'. We declare ten integer variables viz. i,j,m,z,xn,hn,n,xl,hl and q. And also a character variable 'opt'. We ask the user for data and process it accordingly.

Program

//Program for Convolution...

#include<stdio.h>
#include<conio.h>

void main()
{
int x[10],h[10],y[10][10],ans[10];
int i,j,m,z,xn,hn,n,xl,hl,q;
char opt;
do
{
z=0;
clrscr();
printf("\nEnter no. of elements in x(n) : ");
scanf("%d",&xn);
printf("\nEnter x(n) : ");
for(i=0;i<xn;i++)
scanf("%d",&x[i]);
printf("\nEnter the position of 1st element : ");
scanf("%d",&xl);
printf("\nEnter no.of elements in h(n) : ");
scanf("%d",&hn);
printf("\nEnter h(n) : ");
for(i=0;i<hn;i++)
scanf("%d",&h[i]);
printf("\nEnter the position of 1st element : ");
scanf("%d",&hl);

for(i=0;i<hn;i++)
{
for(j=0;j<xn;j++)
{
y[i][j]=x[j]*h[i];
}
}

for(n=0;n<hn;n++)
{
m=0;
for(i=n,j=0;(i>=0)&&(j<xn);i--,j++)
{
m=m+y[i][j];
}
ans[z]=m;
z++;
}
for(n=1;n<xn;n++)
{
m=0;
for(i=hn-1,j=n;(i>=0)&&(j<xn);i--,j++)
{
m=m+y[i][j];
}
ans[z]=m;
z++;
}
clrscr();
printf("\n  x(n)   =  [");
for(i=0;i<xn;i++)
printf("%4d",x[i]);
printf("  ]\n");
q=16+(xl*(-4));
for(i=0;i<q;i++)
printf(" ");
printf("^");
printf("\n\n  h(n)   =  [");
for(i=0;i<hn;i++)
printf("%4d",h[i]);
printf("  ]\n");
q=16+(hl*(-4));
for(i=0;i<q;i++)
printf(" ");
printf("^");
printf("\n\n  y(n)   =  [");
for(i=0;i<z;i++)
printf("%4d",ans[i]);
printf("  ]\n");
q=16+((xl+hl)*(-4));
for(i=0;i<q;i++)
printf(" ");
printf("^");
printf("\n\n\n\n  Do U want to Continue(y/n) : ");
scanf("%s",&opt);
}while(opt=='y');
getch();
}



No comments

Powered by Blogger.