Projeto

Geral

Perfil

Ações

Atividade #1233

Aberta

Analisar Sobrescrita de objetos em referência

Adicionado por Felipe Welington quase 5 anos atrás. Atualizado quase 5 anos atrás.

Situação:
Em andamento
Prioridade:
Normal
Atribuído para:
Início:
25/02/2020
Data prevista:
28/02/2020 (mais de 4 anos atrasado)

Descrição

Essa tarefa tem como intuito verificar alternativas à estrutura In Place Element Structure, uma vez que para transcrição de dados é necessário transcrever dado por dado e não o objeto em si. DataError.png
Como se observa na imagem, o labview não permite tal feito, logo , atualmente, é feito da seguinte forma. Atual.png

Todavia, estudando o funcionamento do In Place Element Structure, sabe-se que somente uma loop pode usar a refência, além de que é percebível que o caminho que tomamos não é efetivo.

Assim, na Branch ObjRefer
Eu introduzo uma função de sincronização. O Notifier:
Vantagens:
Pode mandar um dado objeto entre loops
Pode ser lido por multiplos loops
O loop consumidor espera o loop produtor enviar uma mensagem, isto é a sincronização pode ser feita sem os waits nos loop.
Pode evitar o vazamento de memória atual do código
Desvantagens:
Se o produtor for muito mais rápido que o consumidor pode se perder dados
Não fica armazenada o ultimo dado como a referência


Arquivos

DataError.png (15,4 KB) DataError.png Felipe Welington, 25/02/2020 19:08 h
Atual.png (10,5 KB) Atual.png Felipe Welington, 25/02/2020 19:11 h
Notifier.png (8,56 KB) Notifier.png Felipe Welington, 25/02/2020 19:27 h
Normal.png (7,96 KB) Normal.png Felipe Welington, 25/02/2020 19:27 h

Atualizado por Felipe Welingtonquase 5 anos

Em um primeiro momento
Eu verifiquei se o notifier transcreveria os dados do objeto tanto da visão quanto do game.
E cheguei a conclusão que ele faz isso.
Em seguida
Eu verifiquei a sincronia dos loop em halt, visto que como os robos não executam ação o fps dos loops keeper, offensive e defensive deveriam chegar bem próximo da visão.
Com base nos em transcrição por referência Normal.png
Com base no Notifier ( tanto para visão, quanto para camera) Notifier.png

Vê-se que o wait cria uma pequena perda de eficiência nos loops, enquanto que com o notifier o loop só executara quando receber o dado novo.
Além de que a diferença de tempo da leitura udp à execução do código é menor com o notifier.

Ações #2

Atualizado por Felipe Welingtonquase 5 anos

Testando a troca de grande parte das referências do game por notifiers, vê-se que em um momento os robôs da nossa equipe somem da imagem e o comando do jogo não sai de halt, posto que o notifier não armazena informação para as próximas interações e parte do nosso código utiliza as informações anteriores via referência na parte do game. Então, vejo que a utilização de tal ferramenta pode ser útil na visão para transcrição do loop read udp para o loop da visão, visto que a maior eficiência desse loop pode evitar o atraso do código que acarretaria em armazenamento de pacotes. Todavia, para o resto das referências seria necessário adaptar parte do código.

Ações #3

Atualizado por Gabriel Borges da Conceiçãoquase 5 anos

  • Prioridade alterado de Alta para Normal
Ações #4

Atualizado por Gabriel Borges da Conceiçãoquase 5 anos

Com base no que conversamos e pensamos na quarta-feira, você agora precisa entender o fluxo das informações do código e conseguir determinar quais informações vai passar em cada notifier de cada while.

Vá postando os avanços.

Ações #5

Atualizado por Gabriel Borges da Conceiçãoquase 5 anos

Sugiro fazer teste para analisar diferença de tempo de execução/processamento entre In Place Element Structure e Notifier.

Pega uma VI em branco, coloca dois whiles e utiliza passagem de parâmetros por referência com In Place. Faça o mesmo em outro teste mas utilizando Notifier e passando a mesma informação que no teste anterior. Utilize "get date in time" ou coisa parecida pra analisar quanto tempo demorou cada um.

Na verdade rode esses testes diversas vezes para analisarmos diversas amostras de tempo para garantir que não teve interferência do pc ou algo do tipo.

Também é importante testar se quando um while lê do notifier ele apaga da memória ou não. Porque se apagar, whiles diferentes não conseguirão ler a mesma informação.

Ações #6

Atualizado por Gabriel Borges da Conceiçãoquase 5 anos

Recrie sua branch a partir da dev

Ações

Exportar para Atom PDF