INHOUDSOPGAWE:
2025 Outeur: John Day | [email protected]. Laas verander: 2025-01-23 12:53
Projeto acadêmico para atender cenário de colaboração através da internet para divulgação de desastres naturais, onde será possível a detecção dos acontecimentos através de sensores IOT de temperatura, luminosidade, oscilação (tilte) e botão de Ainda no cenário de colaboração prevemos integração com o Twitter e aplicativos com suporte mqtt para acionamento do alerta.
U kan ook 'n uiteenlopende posisionering van outomatiese e-posse gee en 'n moontlikheid vir fakenews bied. Dit is baie belangrik om 'n belangrike besluit te neem.
Waarskuwing vir menslike boodskappe kan ook oorweeg word vir SMS, e -pos, sirene en Twitter.
Ons kan die rekords gebruik van AWS insluitend IOT CORE, EC2 en SNS
Sensors van DragonBord 410c
kliënte Android mqtt
Stuur dit om die python te voltooi
Skrywers:
Diego Fernandes dos Santos - [email protected]
Gabriel Piovani Moreira dos Santos - [email protected]
Gustavo Venancio Luz - [email protected]
Paulo Henrique Almeida Santos - [email protected]
Stap 1: Dragonbord 410c - Publicação Dos Sensores - Analogicos
Ons kan 'n publieke inskrywing van ons sensore analoog, ons kan die temperatuur van ons eienskappe ook vir ons opspoor en waarneem om 'n variëteit vir ons te maak.
Este alerta começa a contagem regressiva que pode ser suspensa ou acelerada pelo operador.
Ons kan 'n waarskuwing vir 'n tydperk van 60 gebiede, sowel as 'n herhaling van 20 sekondes.
programa rodando dentro da dragon borad 410c
#!/usr/bin/python3import spidev van libsoc import gpio van tyd af slaap
# Importa lib para comunicacao com MOSQUITTO invoer paho.mqtt.client as mqtt
spi = spidev. SpiDev () spi.open (0, 0) spi.max_speed_hz = 10000 spi.mode = 0b00 spi.bits_per_word = 8
#Gebruik 'n porta ADC1 channel_select1 = [0x01, 0x80, 0x00]
#Para usar a porta ADC2 use o seguinte vetor de configuraҧ࣠o channel_select2 = [0x01, 0xA0, 0x00]
def on_connect (mqttc, obj, vlae, rc): print ("rc:" + str (rc))
def on_message (mqttc, obj, msg): print (msg.topic + "" + str (msg.qos) + "" + str (msg.payload))
def on_publish (mqttc, obj, mid): print ("Message ID:" + str (mid) + "\ n") pass
# Kliënte en klante stel die konfigurasies in mqttc = mqtt. Client ()
mqttc.on_message = on_message mqttc.on_connect = on_connect mqttc.on_publish = on_publish
pub = mqtt. Client ("grupo3")
# Met 'n plaaslike gasheer, kan u dit ook toets. broker_address = "34.230.74.201"
pub.connect (makelaaradres)
as _naam _ == '_ hoof_': gpio_cs = gpio. GPIO (18, gpio. DIRECTION_OUTPUT)
met gpio.request_gpios ([gpio_cs]): contador = 0 adc_value_old = 0 adc_value2_old = 0 terwyl contador <50: gpio_cs.set_high () slaap (0.00001) gpio_cs.set_low () rx = spi.xfer (channel_select1_ g)) contador = contador + 1 adc_value = (rx [1] << 8) & 0b1100000000 adc_value = adc_value | (rx [2] & 0xff) adc_value = (((adc_value * 5) / 1024) - 0.5) * 100 druk ("Temperatuur: % f / n" % adc_value) pub.publish ("temperatuura", str (adc_value)) # teste para acionar contador do alarme, teste ultima leitura + 5%
if adc_value_old == 0: adc_value_old = adc_value if adc_value> (adc_value_old*1.05): pub.publish ("ALARME", "ON") print ("Alarmado temperatura") adc_value_old = adc_value sleep (1)
gpio_cs.set_high () slaap (0.00001) gpio_cs.set_low () rx = spi.xfer (channel_select2) gpio_cs.set_high () contador = contador + 1 adc_value2 = (rx [1] << 8) & 0b1100000000 adc_value2 = adc_ (rx [2] & 0xff) adc_value2 = adc_value2 /10 druk ("Luminosidade: % f / n" % adc_value2) pub.publish ("luminosidade", str (adc_value2))
# teste for acionar contador do alarme, teste ultima leitura + 50%
as adc_value2_old == 0: adc_value2_old = adc_value2 if adc_value2> (adc_value2_old*1.5): pub.publish ("ALARME", "ON") print ("Alarmado Luminosidade") adc_value2_old = adc_value2 slaap (3)
Stap 2: Sensores Digitais - Publicação
código para publicação dos sensores digitais
Ons kan die volgende formele inligting vir ons opspoor, of dit kan 'n soortgelyke weergawe wees van die gebruik van die pânico.
ons kan 'n anomalie opdoen of 'n besmette regressiva inskakel.
programa rodando dentro da dragon borad 410c
vanaf libsoc_zero. GPIO invoer knoppie vanaf libsoc_zero. GPIO invoer Kantel van tyd af slaap slaap invoer paho.mqtt.client as mqtt invoer sys
def on_connect (mqttc, obj, flags, rc): print ("Conectado" + str (rc))
def on_message (mqttc, obj, msg): print (msg.topic + "" + str (msg.qos) + "" + str (msg.payload))
def on_publish (mqttc, obj, mid): # print ("Message ID:" + str (mid) + "\ n") pass
def detectaTilt (): count = 0 sleep_count = 0 while True: try: tilt.wait_for_tilt (1) behalwe: sleep_count += 1 else: count += 1 sleep_count += 1 if sleep_count> 999: break
print ("count:", count) if count> 200: pub = mqttc.publish ("TERREMOTO", "ON") pub = mqttc.publish ("SISMOGRAFO", str (count)) # Criamos of client e setamos suas konfigurasie mqttc = mqtt. Client ()
mqttc.on_message = on_message mqttc.on_connect = on_connect mqttc.on_publish = on_publish
topic = "grupo3"
# Met 'n plaaslike gasheer, kan u dit ook toets. mqttc.connect ("34.230.74.201", 1883)
kantel = kantel ('GPIO-A')
btn = Knoppie ('GPIO-C')
terwyl True: sleep (0.25) detectaTilt () as btn.is_pressed (): pub = mqttc.publish ("PANICO", "ON") print ("Botao ON") sleep (1) pub = mqttc.publish ("PANICO "," OFF ") # else: # pub = mqttc.publish (" PANICO "," OFF ") # print (" Botao OFF ")
Stap 3: Codigo Para Acionamento Sirene
Codigo para subscrição para acionamento da SIRENE, programa rodando dentro da dragon board 410c
# Importa lib para comunicacao com MOSQUITTOinvoer paho.mqtt.client as mqtt
vanaf libsoc_zero. GPIO invoer LED van tyd af slaap led = LED ('GPIO-E') #led.off ()
# Definieer o que fazer ao conectar def on_connect (kliënt, obj, vlae, rc): druk ("ConexÃÆ'à £ o estabelecida com broker")
# Definieer die funksie wat ons kan ontvang tydens die definisie van on_message (kliënt, obj, boodskap): druk ("LED" + str (message.payload.decode ("utf-8"))) as str (message.payload.decode ("utf-8")) == "on": print ("Sirene ligada") led.on () else: print ("Sierene apagada") led.off ()
# IP doen makelaar broker_address = "34.230.74.201"
# Cria of cliente sub = mqtt. Client ("grupo3")
subverbinding (makelaaradres)
sub.on_message = on_message sub.on_connect = on_connect
# Verhoog geen sub -sub -intekening nie ("SIRENE", qos = 0)
# Lus vir escuta sub.loop_forever ()
Stap 4: Codigo Twitter - Plaas
Código para publicação do twitter assim que acionado o alarme.
'n virtuele weergawe van AWS EC2
#!/usr/bin/env python #---------------------------------------- ------------------------------- # twitter-post-status #-plaas 'n statusboodskap op u tydlyn # --- -------------------------------------------------- ------------------ invoer paho.mqtt. teken in as inteken
invoer tyd
vanaf Twitter invoer *
#------------------------------------------------- ---------------------- # wat moet ons nuwe status wees? #------------------------------------------------- ---------------------- new_status = "#Terremoto Procure uma zona segura-teste"
#------------------------------------------------- ---------------------- # laai ons API-geloofsbriewe # ---------------------- ------------------------------------------------- invoer sys sys.path.append (".") invoeropstelling
#------------------------------------------------- ---------------------- # skep twitter API-voorwerp # ---------------------- ------------------------------------------------- twitter = Twitter (auth = OAuth ('senha removalida'))
#------------------------------------------------- ---------------------- # plaas 'n nuwe status # twitter API-dokumente: https://dev.twitter.com/rest/reference/post/statu… #------------------------------------------------- ----------------------
terwyl 1: m = subscribe.simple ("twitteralarme", hostnaam = "172.31.83.191", behou = onwaar) as m.topic == "twitteralarme" en str (m.payload.decode ("utf-8")) == "aan": resultate = twitter.statuses.update (status = (new_status)+str (time.time ())) # print ("status opgedateer: % s" % new_status)
Stap 5: Centro De Comando
'n handmatige gebruiksaanwysing of 'n waarskuwingshandleiding vir die gebruik van 'n mens kan ons registreer. U kan die operasie kanselleer of u kan onmiddellik 'n waarskuwing doen.
Vir die gebruik van die bord vir Android vir telefone vir 'n operasionele sentrum.
'n virtuele weergawe van AWS EC2
invoer paho.mqtt.client as pahoimport paho.mqtt.subscribe as subscribe invoer paho.mqtt.publiseer as publiseer import json import time import six import ssl from time import sleep
onderwerpe = ['#']
gatilho = 0 hora_disparo = 0 publish.single ("ACIONADO", "OFF", qos = 1, hostname = "172.31.83.191") publish.single ("sensor1", "OFF", qos = 1, hostname = "172.31.83.191 ") publish.single (" sensor2 "," OFF ", qos = 1, hostname =" 172.31.83.191 ")
connflag = Onwaar
def on_connect (kliënt, gebruikersdata, vlae, rc): global connflag connflag = True print (connflag) print ("Connection return result:" + str (rc))
def on_message (client, userdata, msg): # print ("teste") print (msg.topic+""+str (msg.payload))
def on_log (kliënt, gebruikersdata, vlak, buf): print (msg.topic+""+str (msg.payload))
mqttc = paho. Client ("Broker_MSG") mqttc.on_connect = on_connect mqttc.on_message = on_message
awshost = "data.iot.us-east-1.amazonaws.com" awsport = 8883 clientId = "a2rczvc6ni8105" thingName = "Ufscar2018" caPath = "aws-iot-rootCA.crt" certPath = "9e85dfd42a-certificate.pem. crt "keyPath =" 9e85dfd42a-private.pem.key "mqttc.tls_set (caPath, certfile = certPath, keyfile = keyPath, cert_reqs = ssl. CERT_REQUIRED, tls_version = ssl. PROTOCOL_TLSv1_2, ciphc.sw, keepalive = 60) mqttc.loop_start ()
terwyl 1: hora = time.time () slaap (.1) publish.single ("LEDTERREMOTO", "on", qos = 1, hostname = "172.31.83.191")
# if connflag == True: # mqttc.publish ("message", json.dumps ({'message': "TERREMOTO"}), qos = 1) if gatilho == 1: publish.single ("TEMPO", str (rond (hora_disparo-hora, 0)), qos = 1, hostname = "172.31.83.191") publish.single ("LEDTERREMOTO", "on", qos = 1, hostname = "172.31.83.191") anders: publiseer.single ("TEMPO", "99", qos = 1, hostname = "172.31.83.191") # print ("") if (hora> hora_disparo) en (gatilho == 1): # print ("TERREMOTO") # print (connflag) if connflag == True: # mqttc.publish ("message", json.dumps ({'message': "TERREMOTO"}), qos = 1) # mqttc.publish ("message", "TERREMOTO ", qos = 1) mqttc.publish (" boodskap ", json.dumps (" TERREMOTO - PROCURE UMA ZONA SEGURA "), qos = 1)
# print ("teste SNS") # publish.single ("LED", "on", hostname = "172.31.83.191") publish.single ("SIRENE", "on", qos = 1, hostname = "172.31. 83.191 ") publish.single (" TEMPO "," TERREMOTO ", qos = 1, hostname =" 172.31.83.191 ") publish.single (" ACIONADO "," OFF ", qos = 1, hostname =" 172.31.83.191 ") publish.single ("twitteralarme", "on", qos = 1, hostname = "172.31.83.191") publish.single ("twitter", "TERREMOTO - PROCURE UMA ZONA SEGURA", qos = 1, hostname = "172.31.83.191 ") gatilho = 0 slaap (5) m = subscribe.simple (onderwerpe, gasheernaam =" 172.31.83.191 ", behou = Onwaar) as m.topic ==" ACIONADO "en str (m.payload.decode (" utf-8 ")) ==" OFF ": gatilho = 0 print (" cancelado ") as m.topic ==" medico "en str (m.payload.decode (" utf-8 ")) ==" op ": if connflag == True: mqttc.publish (" medico ", json.dumps (" MEDICOS - EMERGENCIA TERREMOTO "), qos = 1) if m.topic ==" bombeiro "en str (m.payload.decode ("utf -8")) == "on": if connflag == True: mqttc.publish ("bombeiro", json.dumps ("BOMBEIRO - EMERGENCIA TERREMOTO"), qos = 1) if m.topic == " ambulancia "en str (m.payloa d.decode ("utf -8")) == "on": if connflag == True: mqttc.publish ("ambulancia", json.dumps ("AMBULANCIA - EMERGENCIA TERREMOTO"), qos = 1) as m. topic == "urgente" en str (m.payload.decode ("utf-8")) == "on": publish.single ("ACIONADO", 1, qos = 1, hostname = "172.31.83.191") gatilho = 1 hora_disparo = time.time ()+5 if str (m.payload.decode ("utf-8")) == "ON": if gatilho == 1: print ("acelerado 20") hora_disparo = hora_disparo -20 anders: druk ("Acionado") publish.single ("ACIONADO", 1, qos = 1, hostnaam = "172.31.83.191") gatilho = 1 hora_disparo = time.time ()+60
Stap 6: Codigo Twitter - Monitoração
kan u monitor op Twitter, of na 'n regstreekse pos
'n virtuele weergawe van AWS EC2
n
vanaf Twitter invoer *invoer config invoer paho.mqtt.publiseer as publiseer
van tyd af slaap invoer
twitter = Twitter (auth = OAuth (config.access_key, config.access_secret, config.consumer_key, config.consumer_secret))
breedtegraad = -23.546211 lengtegraad = -46.637840 alcance = 50 resultados = 1
publish.single ("twitter_alarme", "ON", hostname = "34.230.74.201")
result_count = 0 last_id = Geen vlag = 0
vir i in bereik (60): #----------------------------------------- ------------------------------ # soek 'n soektog gebaseer op breedtegraad en lengtegraad # twitter API-dokumente: https:// dev. twitter.com/rest/reference/get/search… #------------------------------------- ---------------------------------- probeer: navraag = twitter.search.tweets (q = "#Terremoto", geokode = " %f, %f, %dkm" %(breedtegraad, lengtegraad, alcance), max_id = laaste_id) print ("leu")
behalwe: druk ("erro acesso twitter") breek
vir resultaat in navraag ["status"]:
#------------------------------------------------- ---------------------- # verwerk slegs 'n resultaat as dit 'n geografiese ligging het # ----------------- -------------------------------------------------- ---- if result ["geo"]: result_count += 1 last_id = result ["id"] sleep (1) if result_count == resultados: flag += 1 publish.single ("twitter_alarme", "ON", hostnaam = "34.230.74.201") publish.single ("twitter", "TERREMOTO - DETECTADO", hostname = "34.230.74.201") breek
Stap 7: Estrutura AWS
Gebruik ook virtuele funksies vir die bestuur van AWS EC2
Gebruik en AWS IOT CORE vir MQTT -diens en konfigurasies
Die onderwerpe vir AWS SNS kan ook vir AWS IOT CORE gebruik word
Aanbeveel:
Spelontwerp in vyf stappe: 5 stappe
Spelontwerp in fliek in 5 stappe: Flick is 'n baie eenvoudige manier om 'n speletjie te maak, veral iets soos 'n legkaart, visuele roman of avontuurlike spel
Gesigsopsporing op Raspberry Pi 4B in 3 stappe: 3 stappe
Gesigsopsporing op Raspberry Pi 4B in 3 stappe: in hierdie instruksies gaan ons gesigsopsporing uitvoer op Raspberry Pi 4 met Shunya O/S met behulp van die Shunyaface-biblioteek. Shunyaface is 'n biblioteek vir gesigherkenning/opsporing. Die projek het ten doel om die vinnigste opsporing en herkenningssnelheid te bereik met
DIY Vanity Mirror in eenvoudige stappe (met LED -strookligte): 4 stappe
DIY Vanity Mirror in eenvoudige stappe (met behulp van LED Strip Lights): In hierdie pos het ek 'n DIY Vanity Mirror gemaak met behulp van die LED strips. Dit is regtig cool, en u moet dit ook probeer
Comando Por Voz - DragonBoard410c: 5 stappe
Comando Por Voz - DragonBoard410c: Este guia ir á installeer 'n installasie van die program Julius junto com of Coruja, que s ã o respectivamente um programa de reconhecimento de voz e o modelo ac ú stico em Portugu ê s
Centro De Cómputo Para Niños Con Raspberry Pi: 7 stappe
Centro De Cómputo Para Niños Con Raspberry Pi: Estos ser á n los primeros pasos de la Raspberry Pi and para ello necesitaremos: Raspberry Pi 2 Adaptador of red a micro USB Tarjeta micro SD (de 8 gb) Cable HDMI Cargador Rat ó n Teclado para computadoraEen caso de contar met 'n kit de inicio