Coder Social home page Coder Social logo

mauricio---consumo-de-energia-inteligente's Introduction

Mauricio Santana Muniz

Consumo de energia inteligente

1. Introdução

Considerando as vantagens que a IoT pode proporcionar às pessoas e meio ambiente, o problema proposto foi um sistema automatizado de coleta de dados de energia elétrica de residências e tendo um medidor simulado em código para enviar esses dados. Nessa simulação temos duas aplicações que se comunicam em rede remotamente e também online para realizar cálculos, consultas e realizar todas as funções especificadas para o problema.

2. Fundamentação teorica

Nesta sessão será descrita a base teórica necessária para a resolução do problema.

2.1 API

Segundo a Amazon[1], API significa Application Programming Interface (Interface de Programação de Aplicação). No contexto de APIs, a palavra Aplicação refere-se a qualquer software com uma função distinta. A interface pode ser pensada como um contrato de serviço entre duas aplicações. Esse contrato define como as duas se comunicam usando solicitações e respostas. A documentação de suas respectivas APIs contém informações sobre como os desenvolvedores devem estruturar essas solicitações e respostas.

A arquitetura da API geralmente é explicada em termos de cliente e servidor. A aplicação que envia a solicitação é chamada de cliente e a aplicação que envia a resposta é chamada de servidor. Então, no exemplo do clima, o banco de dados meteorológico do instituto é o servidor e o aplicativo móvel é o cliente.

Existem quatro maneiras diferentes pelas quais as APIs podem funcionar, dependendo de quando e por que elas foram criadas. Nesse problema foi usado API Rest.

API-page-grafic

2.1.1 API Rest

O termo REST significa Representational State Transfer, ou em português, Transferência Representacional de Estado. REST define um conjunto de funções como GET, PUT, DELETE e assim por diante, que os clientes podem usar para acessar os dados do servidor. Clientes e servidores trocam dados usando HTTP.

A principal característica da API REST é a ausência de estado. A ausência de estado significa que os servidores não salvam dados do cliente entre as solicitações. As solicitações do cliente ao servidor são semelhantes aos URLs que você digita no navegador para visitar um site. A resposta do servidor corresponde a dados simples, sem a renderização gráfica típica de uma página da Web.[1]

2.2 Protocolo TCP

TCP/IP é um acrônimo para o termo Transmission Control Protocol/Internet Protocol Suite, dois dos mais importantes protocolos que conformam a pilha de protocolos usados na Internet. O protocolo IP, base da estrutura de comunicação da Internet é um protocolo baseado no paradigma de chaveamento de pacotes (packet-switching).[2]

Os protocolos TCP/IP podem ser utilizados sobre qualquer estrutura de rede, seja ela simples como uma ligação ponto-a-ponto ou uma rede de pacotes complexa. Como exemplo, pode-se empregar estruturas de rede como Ethernet, Token-Ring, FDDI, PPP, ATM, X.25, Frame-Relay, barramentos SCSI, enlaces de satélite, ligações telefônicas discadas e várias outras.

A arquitetura TCP/IP, assim como a OSI, realiza a divisão de funções do sistema de comunicação em estruturas de camadas.[2]

imagemtcp.gif

2.3 Sockets

De acordo com a [3]: “Socket é um ponto de comunicação entre duas máquinas”, ou seja, podemos enviar mensagens entre a máquina A e a máquina B através de uma conexão estabelecida com o Socket.

Para que essa comunicação seja possível, nós precisamos criar a classe Servidora que é responsável por esperar a conexão do cliente e a classe Cliente que irá conectar-se ao Servidor. Antes de iniciarmos a prática e começar a criar nosso ambiente de comunicação, vamos entender as classes que usaremos e seus métodos.

2.4 Threads

Segundo [4] Threads são unidades básicas de processamento em um sistema operacional. Elas representam um fluxo independente de execução dentro de um processo e permitem que várias tarefas sejam executadas simultaneamente dentro de um programa.

As threads compartilham recursos como memória, arquivos abertos e outras informações com o processo pai. Elas são úteis para a execução de tarefas que podem ser paralelizadas, como processamento de imagem, operações de entrada e saída de dados em rede, cálculos intensivos e outras tarefas que podem ser executadas em segundo plano enquanto outras partes do programa continuam a ser executadas.

2.5 Docker

Docker é uma plataforma de software que fornece uma maneira de criar, implantar e executar aplicativos em contêineres. Contêineres são uma forma de virtualização em que um aplicativo é empacotado com todas as suas dependências e é executado como um processo isolado em um sistema operacional hospedeiro compartilhado. Isso torna mais fácil para os desenvolvedores criar aplicativos portáteis que possam ser executados em qualquer lugar, independentemente do sistema operacional ou do hardware subjacente.[5]

3. Resultados e discussões

Para desenvolver esse sistema foi utilizado a linguagem Java, incluindo suas bibliotecas nativas da linguagem, não foi utilizado nenhum framework, foi utilizado de sockets para fazer a comunicação em rede.

Nesse sistema foi feito uma aplicação responsável por cadastrar usuário, assim como atualizar seus dados. Já na outra faz suas consultas de monitorar o consumo de energia; consultar o consumo de cada cliente; gerar fatura a ser paga, assim também como um histórico de todas as faturas para cada cliente; alertar consumo de energia com consumo excessivo ou grande variação de energia.

O sistema a principio iria armazenar seus dados em um arquivo Json, mas devido ao tempo gasto em algumas etapas de desenvolvimento, essa idéia não foi adiante. Pórem boa parte dela ainda segue no código para possíveis melhorias.

Desenvolver aplicações que se comunicam em rede local ou internet é hoje uma necessidade crescente. Neste problema aprendemos a desenvolver este tipo de aplicação usando Java e sockets. Os sockets em Java representam um recurso poderoso para desenvolvimento de aplicações que podem comunicar-se via rede. Apesar de existirem frameworks que facilitam o desenvolvimento de aplicações em rede com Java é importante entender o fundamento da comunicação com sockets que é a base para toda e qualquer aplicação que utiliza comunicação em rede.

3.1 Requisições

As requições foram feitas usando o GET e podem ser feitas através das rotas:

  • http://localhost:7776/3-400-10/11/2010-10:10:10 para cadastrar um medidor com o id: 3; consumo: 400; data medida: 10/11/2010; horário 10:10:10. Quando é feito uma nova requisição utilizando esse id, ele irá atualizar a medida, se for utilizando outro id, um novo medidor é cadastrado.
  • http://localhost:8081/fatura=3=0 para gerar uma fatura para o medidor de id = 3. O =0 não representa nada nessa rota.
  • http://localhost:8081/consumo=3=0 para consultar todo o consumo do medidor de id = 3. O =0 não representa nada nessa rota.
  • http://localhost:8081/alerta=3=0 compara as duas últimas medidas do medidor e faz calculos para saber se ele teve um consumo excessivo e/ou grande variação. O =0 não representa nada nessa rota.
  • http://localhost:8081/historicofatura=3=1 acessa todo histórico de fatura do medidor, com toda a informação gerada pela fatura daquele medidor correspondente a fatura gerada anteriormente, onde agora usamos uma rota /hitoricofatura, mais o identificador id=3 e mais a primeira fatura armazenada em =1
  • http://localhost:8081/historico=3=0 onde é acessado o historico de um cliente seguido de seu identificador. O =0 não representa nada nessa rota.

4. Referências

[1] Whats is an API?. Disponivel em: https://aws.amazon.com/what-is/api/?nc1=h_ls Acesso em 21 de março de 2023.

[2] Introdução à Arquitetura TCP/IP da Internet. Disponivel em: https://www.gta.ufrj.br/grad/03_1/ip-security/paginas/introducao.html Acesso em 21 de março de 2023

[3] Lesson 1: Socket Communications. Disponivel em: https://www.oracle.com/java/technologies/jpl2-socket-communication.html Acesso em 21 de março de 2023

[4] Processes and Threads. Disponivel em: https://docs.oracle.com/javase/tutorial/essential/concurrency/procthread.html Acesso em 21 de março de 2023

[5] Docker: desenvolvimento de aplicações em containers. Disponivel em: https://www.redhat.com/pt-br/topics/containers/what-is-docker Acesso em 21 de março de 2023

mauricio---consumo-de-energia-inteligente's People

Contributors

mauriciomuniz avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.