Thursday 10 August 2017

Mudar De Média Applet


Importar java. awt. Importar java. applet. Importa java. lang. Thread import java. lang. Classe pública Movingball extends Applet Thread t int i int x34, y14 public void init () tnew Thread () public void paint (Gráficos g) para (i1ilt5i) g. fillOval (x, y, 40,40) g. setColor (Color. red) xx30 yy30 repaint () public static void main (String args) Movingball mbnew Movingball () No programa acima, gostaria de fazer a bola aparecer como se estivesse rolando. Eu ficaria grato se você ajudar. 9 de fevereiro de 2010 às 12:27. Experimente o seguinte código import javax. swing. Importe java. util. Importar java. awt. Classe pública Movingball se estende JApplet int x, y int X1, Y1 int R 10 int S 10 java. util. Timer timer TimerTask tarefa public void init () x75 y50 X12S Y1S timer nova java. util. Timer () tarefa nova TimerTask () Public void run () x X1 y Y1 se ((xR) lt 0) X1 -1 mais se ((xR) gt getWidth ()) X1 -1 se ((yR) lt 0) Y1 -1 mais se ((yR ) Gt getHeight ()) Y1 -1 Gráficos g getGraphics () g. setColor (Color. WHITE) g. fillRect (0,0, getWidth (), getHeight ()) g. setColor (Color. BLUE) g. fillOval ( XR, yR, R2, R2) timer. schedule (tarefa. 0, 50) Ligue para este applet com o seguinte applet. html: lthtmlgt ltbodygt lth1gtJava Applet Demolth1gt ltapplet codeMovingball. class width500 height400gt ltappletgt ltbodygt lthtmlgt Para mais informações, visite o seguinte link : 23 de abril de 2012 às 4:26 PM eu preciso mover um objeto com velocidade ou velocidade diferente que deve ser acelerada. Como classificamos THE SPEED é de 30 km h ou 20 km ou 2 kmhr. Me responda Email ID Deleted 23 de abril de 2012 às 4:27 PM eu preciso de um objeto para mover com velocidade. Acelerar e acelerar isso. Como um objeto pode se mover com velocidade 30 km por hora. 20 km. Hr ou 3 km hr, obrigado por nos dar knowledege og java em vários blogs e publicações Tutoriais RelacionadosQuestions Respostas: Moving ball - Applet java. lang. Thread import java. lang. Classe pública A bola em movimento estende o Applet. ) Public static void main (String args) No programa acima, gostaria de fazer aparecer a bola Movendo as imagens Movendo as imagens Como mover várias imagens em um quadro usando baloiços Como projetar uma bola de golfe, projetar uma bola de golfe, um Bola de golfe Como desenhar uma bola de golfe Faça a sua própria forma de bola de golfe, pegue a ajuda deste exemplo. Novo arquivo: pegue um novo arquivo. Padrão de meio-tom: vá para o menu de filtro gt Função de movimento de esboço - Função de deslocamento Java3D Estou trabalhando em um projeto em java. Pode ser a sua função disponível para a velocidade. Eu quero mover 2d bola com a velocidade adequada. Posso aumentar ou acelerar a velocidade com a ajuda da função java Olá amigo Como desenhar uma bola de cricket saltando, projetar uma bola de cricket rebocadora, bola de cricket Como desenhar uma bola de cricket saltando Agora você pode saltar uma bola de cricket usando. Uma bola de cricket. Capture uma bola. Capture qualquer foto de bola de cricket e configure Como fazer uma bola de futebol explosão, faça uma bola de futebol explosão, bola de futebol explosão Como fazer uma bola de futebol explosão Você tem a chance de aprender uma bola de futebol com este exemplo, eu estou completamente descrito para aprender facilmente. Imagem de bola: primeiro a ter um futebol Manhattan Moving Services Manhattan Moving Services Deleted by admin - Shleppers Movendo a função de amplificador para balançar a bola com o ângulo apropriado - Função Java3D para balançar a bola com o ângulo apropriado, como eu posso balançar. Java. awt. Importe java. util. Classe pública Bola Moving Applet Problema Applet Mudando Problema Quando a imagem se desloca no applet, uma imagem piscando está funcionando continuamente. Como remover esse piscar. Importar java. applet. Applet importar java. awt. Color importar java. awt. Graphics importar quadro de monitoramento para mover continuamente a estrutura de monitoramento de objetos para objetos em movimento contínuo oi, eu quero um código-fonte se o objeto se mover para fora da região segura que eu quero Obtenha a atualização para o servidor Movendo Imagens na GUI - Swing AWT Movendo Imagens na GUI Eu quero adicionar uma imagem de uma pessoa na minha GUI e fazê-la mover-se para um local específico. Como posso adicionar a imagem ao quadro e mover desenhar o gráfico em execução ou em movimento usando o banco de dados em jsp, desenhe o gráfico em execução ou em movimento usando o banco de dados em jsp, minha pergunta é como desenhar o gráfico em execução ou em movimento usando jsp e pegue x e y Coordenar o valor do banco de dados desenhar o gráfico em execução ou em movimento usando o banco de dados em jsp desenhar o gráfico em execução ou em movimento usando o banco de dados em jsp oi minha pergunta é como desenhar o gráfico em execução ou em movimento usando jsp e pegue o valor de coordenada xey do Banco de dados como escrever código de média móvel ponderada usando 2d-array como escrever código de média móvel ponderada usando 2d-array como escrever código de média móvel ponderada usando 2d-array Projetos em movimento de tomcat-6.0 para jboss 5.0.1 GA Projetos em movimento de Tomcat -6.0 para jboss 5.0.1 GA Agora estou usando o servidor Tomcat version6.0 para o meu projeto. Agora eu quero mudar o servidor do tomcat para jboss 5.0.1 GA. Quais são as coisas que eu tenho que fazer para usar o jboss em vez da grade GXT movendo o lado direito após o lado direito Grade GXT movendo o lado direito após o alinhamento direito Eu criei uma grade gxt. Existem 7 colunas e a última coluna alinha-se como DIREITO. Movendo o lado direito 2px. Então, como posso corrigir os drop downs de Jkmegamenu que se deslocam para a esquerda quando a janela é redimensionada no Chrome Jkmegamenu drop downs movendo-se para a esquerda quando a janela é redimensionada no Chrome Im usando o plugin JKmegamenu para implementar um megamenu em um site em que estou trabalhando. Funciona e parece legal, no entanto, quando a janela do navegador da Web (Chrome) Exemplo de cópia e movimentação de Oracle VirtualBox VM para outra máquina Exemplo de cópia e movimentação de Oracle VirtualBox VM para outra máquina Oi, qual poderia ser o melhor e mais fácil método para copiar um Vm de uma máquina para outra máquina. Eu quero mover uma VM da caixa Virtual do Oracle para outro Cursor em Movimento dentro do Seletor de Movimento ResultSet Dentro do ResultSet Existem vários métodos para mover. Direcionar System. out. println (Avançar) enquanto (resultSet. next. Moving Forward Roll No 1, Nome Rajan, Course MCA, Endereço Motihari Movendo uma coluna no JTable Movendo uma coluna no componente JTable nbsp. Moving é um método muito simples Que move os dados das colunas. Descrição do programa: Este programa ajuda você a mover uma coluna Mover Div por botão clicar usando efeito animado Mover Div por botão clicar usando efeito animado Neste tutorial discutiremos como mover 39div39 esquerda-direita Com o botão, clique em jQuery. Neste exemplo, 39div39 está se movendo para a esquerda direita pelo botão direito da esquerda, clique em Movendo o arquivo ou diretório de um diretório para outro. Movendo o arquivo ou o diretório de um diretório para outro. Ilustra o método ou procedimento para mover um arquivo ou Método do conteúdo do diretório para completar o programa para mover o arquivo ou a pasta completa da cópia e movimentação de dados usando o arrastar e soltar Copiar e mover dados usando arrasto e soltar: você pode arrastar e soltar os dados de l Ist to dataGrid usando diferentes formatos de dados neste exemplo. Quando você move os dados e adiciona-o ao alvo de queda, ele será removido do exemplo do Thread de salto de desenho. A forma da bola é dada por graphics. fillOval (p, q. P, Q). Aqui. Aplicativo que cria uma bola que salta com a ajuda de thread em Gráficos. Ao pressionar o botão Iniciar, a classe ActionListener é chamada e a bola Bouncing Thread Example. A forma da bola é dada por graphics. fillOval (p, q. P, Q). Aqui. Aplicativo que cria uma bola que salta com a ajuda de thread em Gráficos. Ao pressionar o botão Iniciar, a classe ActionListener é chamada e a bola Spark Move3D Efeito no Flex4 Spark Move3D Efeito no Flex4: O efeito Move3D é usado para mover o componente no sistema de coordenadas x, y e z. Se você especificar o movimento na direção z, o efeito parecerá um efeito Zoom. A tag do efeito Move3D é lts Serviços de rastreamento de frotas Os serviços de rastreamento de frotas ajudam pessoas em empresas de frotas a conhecer a localização exata de sua frota em movimento. Esses dispositivos estão pré-instalados nos veículos, que então coletam todas as informações relacionadas ao veículo e as armazenam, também jQuery estado de transição em cadeia jQuery estado de transição em cadeia Neste tutorial JQuery, desenvolveremos um programa que altera a Estado de transição do movimento da caixa inicial esquerdo - gt Direito O que é GPS diferencial a precisão a menos de dois metros da posição real para mover objetos. E o outro se move em torno de fazer medições de posição. Aqui. De erro como o receptor móvel. O receptor estacionário, em seguida, funciona de volta para as Aplicações de pesquisa de restaurantes. Encontre Novos locais para comer, Aplicativos rápidos de pesquisa de restaurantes ndash Encontre novos lugares para comer, Fast Os telefones celulares passaram de ser funcionais até serem uma bola de diversão que ajuda você a se manter conectado e tirar mais proveito da vida. As aplicações são uma ótima maneira. Como outras pessoas mencionaram, você deve considerar um filtro IIR (resposta de impulso infinito) em vez do filtro FIR (filtro de resposta finito) que você está usando agora. Há mais, mas à primeira vista os filtros FIR são implementados como convoluções explícitas e filtros IIR com equações. O filtro IIR particular que eu uso muito em microcontroladores é um filtro passa-baixa de um único pólo. Este é o equivalente digital de um simples filtro analógico R-C. Para a maioria dos aplicativos, estes terão melhores características do que o filtro de caixa que você está usando. A maioria dos usos de um filtro de caixa que eu encontrei são resultado de alguém que não presta atenção na classe de processamento de sinal digital, não como resultado de precisar de suas características particulares. Se você quiser apenas atenuar as altas freqüências que você conhece são ruim, um filtro passa-baixa de um único pólo é melhor. A melhor maneira de implementar um digitalmente em um microcontrolador é geralmente: FILT lt-- FILT FF (NEW-FILT) FILT é um pedaço de estado persistente. Esta é a única variável persistente que você precisa para calcular esse filtro. NOVO é o novo valor que o filtro está sendo atualizado com esta iteração. FF é a fração do filtro. Que ajusta o peso do filtro. Olhe para este algoritmo e veja que para FF 0 o filtro é infinitamente pesado, já que a saída nunca muda. Para FF 1, realmente não há nenhum filtro, já que a saída apenas segue a entrada. Os valores úteis estão no meio. Em pequenos sistemas, você escolhe FF para ser 12 N, de modo que o multiplica por FF possa ser realizado como uma mudança direta por N bits. Por exemplo, FF pode ser 116 e multiplicar por FF, portanto, um deslocamento direito de 4 bits. Caso contrário, este filtro precisa apenas de uma subtração e de um som, embora os números geralmente precisem ser maiores do que o valor de entrada (mais na precisão numérica em uma seção separada abaixo). Normalmente, tomo as leituras de AD significativamente mais rápido do que elas são necessárias e aplique dois desses filtros em cascata. Este é o equivalente digital de dois filtros R-C em série e atenua 12 dBoctave acima da frequência de rolagem. No entanto, para as leituras de AD, geralmente é mais relevante olhar para o filtro no domínio do tempo, considerando sua resposta passo a passo. Isso indica o quão rápido o sistema verá uma mudança quando a coisa que você está medindo muda. Para facilitar a concepção desses filtros (o que significa apenas escolher FF e decidir quantos deles entrar em cascata), uso meu programa FILTBITS. Você especifica o número de bits de mudança para cada FF na série de filtros em cascata, e ele calcula a resposta de passo e outros valores. Na verdade, eu costumo executar isso através do meu script wrapper PLOTFILT. Isso executa FILTBITS, que faz um arquivo CSV, e enche o arquivo CSV. Por exemplo, aqui é o resultado do PLOTFILT 4 4: Os dois parâmetros para PLOTFILT significam que haverá dois filtros em cascata do tipo descrito acima. Os valores de 4 indicam o número de bits de mudança para realizar o multiplicar pelo FF. Os dois valores FF são, portanto, 116 neste caso. O traço vermelho é a resposta do passo da unidade, e é o principal aspecto a ser observado. Por exemplo, isso indica que, se a entrada muda instantaneamente, a saída do filtro combinado será fixada em 90 do novo valor em 60 iterações. Se você se preocupa com 95 horas de colonização, então você precisa esperar cerca de 73 iterações e por 50 horas de assentamento apenas 26 iterações. O traço verde mostra a saída de um único pico de amplitude total. Isso dá uma idéia da supressão de ruído aleatória. Parece que nenhuma amostra única causará mais do que uma mudança de 2.5 na saída. O traço azul é dar uma sensação subjetiva do que este filtro faz com o ruído branco. Este não é um teste rigoroso, uma vez que não há garantia de que exatamente o conteúdo era dos números aleatórios escolhidos como a entrada de ruído branco para esta corrida de PLOTFILT. É só dar-lhe uma sensação áspera de quanto será esmagado e quão suave é. PLOTFILT, talvez FILTBITS, e muitas outras coisas úteis, especialmente para o desenvolvimento de firmware PIC, estão disponíveis na versão do software PIC Development Tools na minha página de downloads de software. Adicionado sobre a precisão numérica que vejo a partir dos comentários e agora uma nova resposta que tem interesse em discutir o número de bits necessários para implementar este filtro. Observe que o multiplicar pelo FF criará novos bits do Log 2 (FF) abaixo do ponto binário. Em sistemas pequenos, o FF é geralmente escolhido para ser 12 N, de modo que esse multiplicação seja efetivamente realizado por uma mudança direta de N bits. FILT é, portanto, geralmente um número inteiro de ponto fixo. Observe que isso não altera nenhuma das matemáticas do ponto de vista dos processadores. Por exemplo, se você estiver filtrando as leituras AD de 10 bit e N 4 (FF 116), então você precisa de 4 bits de fração abaixo das leituras AD inteiras de 10 bits. Na maioria dos processadores, você estará fazendo operações inteiras de 16 bits devido às leituras AD de 10 bits. Nesse caso, você ainda pode fazer exatamente as mesmas operações de inteiro de 16 bits, mas comece com as leituras AD esquerda deslocadas em 4 bits. O processador não conhece a diferença e não precisa. Fazer matemática em inteiros inteiros de 16 bits funciona se você considera que eles são 12.4 pontos fixos ou verdadeiros inteiros de 16 bits (16.0 ponto fixo). Em geral, você precisa adicionar N bits a cada pólo de filtro se você não deseja adicionar ruído devido à representação numérica. No exemplo acima, o segundo filtro de dois teria que ter 1044 18 bits para não perder informações. Na prática, em uma máquina de 8 bits que significa que você use valores de 24 bits. Tecnicamente, apenas o segundo pólo de dois precisaria do valor mais amplo, mas, para a simplicidade do firmware, costumo usar a mesma representação e, assim, o mesmo código, para todos os pólos de um filtro. Normalmente, eu escrevo uma sub-rotina ou macro para executar uma operação de pólo de filtro e, em seguida, aplique isso para cada pólo. Se uma sub-rotina ou macro depende se os ciclos ou a memória do programa são mais importantes nesse projeto particular. De qualquer forma, eu uso algum estado de rascunho para passar NOVO no subroutinemacro, que atualiza FILT, mas também carrega isso no mesmo estado de rascunho NOVO estava dentro. Isso facilita a aplicação de vários pólos desde que o FILT atualizado de um pólo é o NOVO Do próximo. Quando uma sub-rotina, é útil ter um ponteiro apontar para FILT no caminho, que é atualizado logo após FILT no caminho de saída. Dessa forma, a sub-rotina atua automaticamente em filtros consecutivos na memória se for chamado várias vezes. Com uma macro, você não precisa de um ponteiro, pois você passa no endereço para operar em cada iteração. Exemplos de código Aqui está um exemplo de uma macro como descrito acima para um PIC 18: E aqui está uma macro semelhante para um PIC 24 ou dsPIC 30 ou 33: Ambos os exemplos são implementados como macros usando o meu pré-processador PIC assembler. Que é mais capaz do que qualquer uma das instalações de macro incorporadas. Clabacchio: Outro problema que eu deveria ter mencionado é a implementação do firmware. Você pode escrever uma sub-rotina de filtro passa-baixa de um único pó uma vez, e depois aplicá-la várias vezes. Na verdade, costumo escrever uma sub-rotina para levar um ponteiro na memória para o estado do filtro, então faça avançar o ponteiro para que possa ser chamado sucessivamente de forma fácil para realizar filtros multipolar. Ndash Olin Lathrop 20 de abril 12 às 15:03 1. Muito obrigado por suas respostas - todos eles. Eu decidi usar este Filtro IIR, mas este Filtro não é usado como um Filtro LowPass Padrão, pois eu preciso usar os Valores de Contador médios e compará-los para detectar Mudanças em um determinado intervalo. Uma vez que estes valores são de dimensões muito diferentes dependendo do hardware que eu queria tomar uma média para poder reagir automaticamente a essas mudanças específicas de hardware. Ndash sensslen 21 de maio 12 às 12:06 Se você pode viver com a restrição de um poder de dois itens a média (ou seja, 2,4,8,16,32 etc.), então a divisão pode ser feita com facilidade e eficiência em um Micro de baixo desempenho sem nenhuma divisão dedicada porque pode ser feito como uma mudança de bit. Cada turno para a direita é um poder de dois, por exemplo: O OP pensou que ele tinha dois problemas, dividindo-se em um PIC16 e memória para o buffer de anel. Esta resposta mostra que a divisão não é difícil. É certo que não aborda o problema de memória, mas o sistema SE permite respostas parciais, e os usuários podem tirar algo de cada resposta por si mesmos, ou mesmo editar e combinar as respostas de outros. Uma vez que algumas das outras respostas exigem uma operação de divisão, elas são igualmente incompletas, uma vez que não mostram como conseguir isso eficientemente em um PIC16. Ndash Martin 20 de abril 12 às 13:01 Há uma resposta para um verdadeiro filtro de média móvel (aka filtro de caixa) com menos requisitos de memória, se você não se importa com o downsampling. É chamado de filtro integrador-pente em cascata (CIC). A idéia é que você tenha um integrador que você tome diferenças em um período de tempo, e o dispositivo chave de economia de memória é que, por downsampling, você não precisa armazenar todos os valores do integrador. Ele pode ser implementado usando o seguinte pseudocódigo: Seu comprimento efetivo da média móvel é decimationFactorstatesize, mas você só precisa manter em torno de amostras estadisticas. Obviamente, você pode obter um melhor desempenho se o seu Stateization e decimationFactor forem poderes de 2, de modo que os operadores de divisão e restante sejam substituídos por turnos e máscaras-ands. Postscript: eu concordo com a Olin que você sempre deve considerar filtros IIR simples antes de um filtro de média móvel. Se você não precisa da freqüência-nulo de um filtro de caixa, um filtro passa-baixa de 1 pólo ou 2 pólos provavelmente funcionará bem. Por outro lado, se você estiver filtrando para fins de decimação (tomando uma entrada de alta taxa de amostragem e avaliando-a para uso por um processo de baixa taxa), então um filtro CIC pode ser exatamente o que você está procurando. (Especialmente se você puder usar statesize1 e evitar a compatibilidade do ringbuffer com apenas um único valor de integrador anterior) Há uma análise aprofundada da matemática por trás do uso do filtro IIR de primeira ordem que Olin Lathrop já descreveu na troca de pilha de processamento de sinal digital (Inclui muitas imagens bonitas.) A equação para este filtro IIR é: Isto pode ser implementado usando apenas números inteiros e sem divisão usando o seguinte código (pode precisar de alguma depuração como eu estava digitando de memória.) Este filtro se aproxima de uma média móvel de As últimas K amostras, definindo o valor de alfa para 1K. Faça isso no código anterior, definindo BITS para LOG2 (K), ou seja, para K 16, defina BITS para 4, para K 4 defina BITS para 2, etc. (Verifique o código listado aqui assim que eu recebo uma alteração e Edite esta resposta, se necessário.) Respondeu 23 de junho 12 às 4:04 Heres um filtro passa-baixa de um único polo (média móvel, com freqüência de corte CutoffFrequency). Muito simples, muito rápido, funciona muito bem, e quase sem memória extra. Nota: Todas as variáveis ​​têm um alcance além da função de filtro, exceto o passado em newInput Note: Este é um filtro de estágio único. Múltiplos estágios podem ser conectados em cascata para aumentar a nitidez do filtro. Se você usar mais de um estágio, você terá que ajustar DecayFactor (como se relaciona com a frequência de corte) para compensar. E, obviamente, tudo que você precisa é aquelas duas linhas colocadas em qualquer lugar, elas não precisam de sua própria função. Este filtro possui um tempo de aceleração antes que a média móvel represente a do sinal de entrada. Se você precisar ignorar esse tempo de aceleração, você pode inicializar MovingAverage para o primeiro valor de newInput em vez de 0 e espero que o primeiro newInput não seja um outlier. (CutoffFrequencySampleRate) tem uma faixa entre 0 e 0,5. DecayFactor é um valor entre 0 e 1, geralmente perto de 1. Os carros de precisão única são bons o suficiente para a maioria das coisas, eu apenas prefiro duplas. Se você precisa ficar com números inteiros, você pode converter DecayFactor e Factor de amplitude em números inteiros fracionários, nos quais o numerador é armazenado como o inteiro e o denominador é um poder inteiro de 2 (para que você possa mudar de bit para a direita como o Denominador em vez de ter que dividir durante o loop do filtro). Por exemplo, se DecayFactor 0.99 e você deseja usar números inteiros, você pode definir o DecayFactor 0.99 65536 64881. E então, quando você se multiplicar pelo DecayFactor no loop do filtro, basta mudar o resultado 16. Para obter mais informações sobre isso, um excelente livro é esse Online, capítulo 19 em filtros recursivos: dspguidech19.htm PS Para o paradigma da Média em Movimento, uma abordagem diferente para definir DecayFactor e AmplitudeFactor que pode ser mais relevante para suas necessidades, digamos que você quer o anterior, cerca de 6 itens em média, fazendo isso discretamente, você adicionará 6 itens e dividirá por 6, então Você pode configurar o AmplitudeFactor para 16, e DecayFactor para (1.0 - AmplitudeFactor). Respondeu 12 de maio 12 às 22:55 Todos os outros comentaram completamente sobre a utilidade do IIR vs. FIR e sobre a divisão de poder de dois. Eu gostaria de dar alguns detalhes de implementação. O abaixo funciona bem em pequenos microcontroladores sem FPU. Não há multiplicação, e se você mantém N um poder de dois, toda a divisão é de mudança de bit de ciclo único. Tampão de anel FIR básico: mantenha um buffer de execução dos últimos valores de N e uma SOM em execução de todos os valores no buffer. Cada vez que uma nova amostra vem, subtrair o valor mais antigo no buffer de SUM, substituí-lo pela nova amostra, adicionar a nova amostra a SUM e saída SUMN. Tampão de anel IIR modificado: mantenha uma SOM executória dos últimos valores de N. Cada vez que uma nova amostra vem, SUM - SUMN, adicione a nova amostra e saia SUMN. Respondeu 28 de agosto às 13:45 Se eu já lendo você direito, você está descrevendo um filtro IIR de primeiro ordem, o valor que você está subtraindo não é o valor mais antigo que está caindo, mas é a média dos valores anteriores. Os filtros IIR de primeiro ordem certamente podem ser úteis, mas eu não tenho certeza do que você quer dizer quando você sugere que a saída seja a mesma para todos os sinais periódicos. A uma taxa de amostragem de 10KHz, a alimentação de uma onda quadrada de 100Hz em um filtro de caixa de 20 estágios produzirá um sinal que sobe uniformemente para 20 amostras, fica alto para 30, cai uniformemente para 20 amostras e fica com baixo para 30. Uma ordem de primeira ordem Filtro IIR. Ndash supercat 28 de agosto 13 às 15:31 renderá uma onda que começa a subir bruscamente e gradualmente se nivela perto (mas não em) o máximo de entrada, então começa a cai e gradualmente nivela perto (mas não em) o mínimo de entrada. Comportamento muito diferente. Ndash supercat 28 de agosto 13 às 15:32 Uma questão é que uma média móvel simples pode ou não ser útil. Com um filtro IIR, você pode obter um bom filtro com relativamente poucos calcs. O FIR que você descreve só pode dar-lhe um retângulo no tempo - um sinc na freq - e você pode gerenciar os lobos laterais. Pode valer a pena lançar alguns números inteiros para tornar uma boa FIR sintonizada simétrica se você pode poupar os tiques do relógio. Ndash Scott Seidman 29 de agosto 13 às 13:50 ScottSeidman: Não há necessidade de se multiplicar se alguém simplesmente tiver cada estágio da FIR, quer a saída da média da entrada para esse estágio e seu valor armazenado anterior, e depois armazene a entrada (se tiver O intervalo numérico, pode-se usar a soma em vez da média). Se isso é melhor do que um filtro de caixa depende da aplicação (a resposta de passo de um filtro de caixa com um atraso total de 1 ms, por exemplo, terá um pico d2dt desagradável quando a entrada muda e, novamente, 1 ms depois, mas terá o mínimo Possível ddt para um filtro com um atraso total de 1ms). Ndash supercat 29 de agosto 13 às 15:25 Como mikeselectricstuff disse, se você realmente precisa reduzir suas necessidades de memória e você não se importa que sua resposta de impulso seja exponencial (em vez de um pulso retangular), eu iria por um filtro exponencial de média móvel . Eu os uso extensivamente. Com esse tipo de filtro, você não precisa de nenhum buffer. Você não precisa armazenar N amostras passadas. Apenas um. Então, seus requisitos de memória são reduzidos por um fator de N. Além disso, você não precisa de nenhuma divisão para isso. Somente multiplicações. Se você tiver acesso à aritmética de ponto flutuante, use as multiplicações de ponto flutuante. Caso contrário, faça multiplicações inteiras e mude para a direita. No entanto, estamos em 2012, e eu recomendaria que você usasse compiladores (e MCUs) que permitem que você trabalhe com números de ponto flutuante. Além de ser mais eficiente e mais rápido (você não precisa atualizar itens em qualquer buffer circular), eu diria que também é mais natural. Porque uma resposta exponencial de impulso corresponde melhor à maneira como a natureza se comporta, na maioria dos casos. Respondeu 20 de abril 12 às 9:59 Um problema com o filtro IIR como quase tocado por olin e supercat, mas aparentemente desconsiderado por outros é que o arredondamento apresenta alguma imprecisão (e potencialmente biastruncagem). Assumindo que N é um poder de dois, e apenas uma aritmética inteira é usada, a direita de mudança elimina sistematicamente os LSBs da nova amostra. Isso significa que, quanto tempo a série possa ser, a média nunca levará em consideração isso. Por exemplo, suponha uma série que diminua lentamente (8,8,8. 8,7,7,7. 7,6,6) e assume que a média é de fato 8 no início. A amostra do punho 7 trará a média para 7, independentemente da força do filtro. Apenas para uma amostra. A mesma história para 6, etc. Agora pense no contrário. A série sobe. A média permanecerá em 7 para sempre, até que a amostra seja grande o suficiente para fazê-la mudar. Claro, você pode corrigir o viés, adicionando 12N2, mas isso realmente não resolverá o problema de precisão. Nesse caso, a série decrescente permanecerá para sempre em 8 até a amostra ser 8-12 (N2). Para N4, por exemplo, qualquer amostra acima de zero manterá a média inalterada. Eu acredito que uma solução para isso implicaria manter um acumulador de LSBs perdidos. Mas eu não conseguiria o suficiente para ter código pronto, e não tenho certeza de que isso não prejudicaria o poder IIR em alguns outros casos de séries (por exemplo, se 7,9,7,9 seria de 8). Olin, sua cascata de dois estágios também precisaria de alguma explicação. Você quer dizer segurar dois valores médios com o resultado do primeiro alimentado no segundo em cada iteração. Qual é o benefício disso

No comments:

Post a Comment