Convolução 1D
Publicado por Rodrigo Vasconcelos de Barros 30/05/2009
[ Hits: 13.758 ]
Algorítimo para convolução de sinais 1D (vetores) em C++ (mas pode ser adaptado para C sem problemas).
Eu tentei deixá-lo bem genérico, por isso talvez algumas passagens não fiquem claras, mas se tiverem qualquer dúvida não deixem de perguntar.
Se encontrarem algum furo, por favor avisem!
#include <iostream> int *conv(int n,int m,int vet_maior,int vet_menor) // vetor a,vetor b,num de elementos dos dois m>n { int vet_a[n],vet_b[m],*vet_conv[n+m-1],aux[m+2*(n-1)]; for (int i=0;i<n+m-1;i++) { if (i<n) vet_a[i]=vet_menor[i]; if (i<m) vet_b[i]=vet_maior[i]; vet_conv[i]=0; } unsigned int x=0; //aux contadora for (int i=0;i<m+2*(n-1);i++) { if (i<n-1) aux[i]=0; //parte nula else { if (i<n+m-1) { aux[i]=vet_b[x]; //parte = vet_maior x++; } else aux[i]=0; //parte nula } } // convolucao for (int j=0;j<n+m-1;j++) { for (int k=0;k<n;k++) { vet_conv[j]+=vet_a[n-1-k]*aux[j+k]; } } // Imprime resultados (caso precise testar) std::cout << "Vetor A:" << std::endl; for (int i=0;i<n;i++){ std::cout << vet_a[i] << " "; } std::cout << std::endl; std::cout << "Vetor B:" << std::endl; for (int i=0;i<m;i++){ std::cout << vet_b[i] << " "; } std::cout << std::endl; std::cout << "Convolucao:" << std::endl; for (int i=0;i<n+m-1;i++){ std::cout << vet_conv[i] << " "; } return (vet_conv); }
Formatar strings em C (RG, telefone, CEP etc)
função de inserção em uma Arvore
Aprenda a Gerenciar Permissões de Arquivos no Linux
Como transformar um áudio em vídeo com efeito de forma de onda (wave form)
Como aprovar Pull Requests em seu repositório Github via linha de comando
Aplicativo simples para gravar tela
Quebra de linha na data e hora no Linux Mint
Firefox não abre em usuário não administradores (2)
Ubuntu com problemas no áudio (1)
Sempre que vou baixar algum pacote acontece o erro dpkg (8)
tentando instalar em um notebook antigo o Linux LegacyOS_2023... [RESO... (8)