Code gehört und Fehlermeldungen gehören immer in den Beitrag. Am besten zwischen Code-Tags. Bilder sind fürchterlich umständlich. Das war also richtig.
Das ist kein Fehler im Code sondern in der Bibliothek. Das scheint auch bekannt zu sein. Habt ihr euch mal die URL angeschaut, die in der Fehlermeldung steht?
Navigation eines Autonomen-Roboters mittels Kamera
Hast du dir auch die Lösungen angeschaut und versucht? Damit sollte sich das Problem unter Windows beheben lassen - nämlich indem du Numpy in der Version 1.19.3 installierst. Und zwar so:
Code: Alles auswählen
pip install numpy==1.19.3
Hallo nochmals,
wir haben soweit ein Programm und wollen es eigentlich nur noch testen. Letzte Woche haben wir bereits eine Strecke aufgebaut aus Papier welche wir ca. 4 Fingerbreit geschnitten haben. Allerdings fehlt unserem Fahrzeug noch einiges.. Wir haben bis jetzt nur die Motoren und die Räder drauf montiert so das wirs mit eigener Hand bewegen können. Uns fehlt aber noch die Halterung für die Kamera wo wir uns noch was einfallen lassen müssen (etwas einfaches am Anfang für die Aufnahme).
Wir haben bereits ein Video von der Strecke, ist allerdings nicht das beste da wir die Kamera mit eigener Hand halten mussten.. Wir arbeiten bereits am Pi und verwenden Pycharm.
Meine Frage wäre ob jemand weiß wie man das aufgenommene Video in Pycharm ins Programm einfügen kann. (Alles ist auf dem Pi, kann aber auch aufs PC übertreagen werden).
LG
Emre
wir haben soweit ein Programm und wollen es eigentlich nur noch testen. Letzte Woche haben wir bereits eine Strecke aufgebaut aus Papier welche wir ca. 4 Fingerbreit geschnitten haben. Allerdings fehlt unserem Fahrzeug noch einiges.. Wir haben bis jetzt nur die Motoren und die Räder drauf montiert so das wirs mit eigener Hand bewegen können. Uns fehlt aber noch die Halterung für die Kamera wo wir uns noch was einfallen lassen müssen (etwas einfaches am Anfang für die Aufnahme).
Wir haben bereits ein Video von der Strecke, ist allerdings nicht das beste da wir die Kamera mit eigener Hand halten mussten.. Wir arbeiten bereits am Pi und verwenden Pycharm.
Meine Frage wäre ob jemand weiß wie man das aufgenommene Video in Pycharm ins Programm einfügen kann. (Alles ist auf dem Pi, kann aber auch aufs PC übertreagen werden).
LG
Emre
- __blackjack__
- User
- Beiträge: 13938
- Registriert: Samstag 2. Juni 2018, 10:21
- Wohnort: 127.0.0.1
- Kontaktdaten:
@Emre: Die Frage hört sich komisch an. Man fügt keine Videos in Programme ein und was hat das mit der IDE zu tun? Das Video ist ja eine Datei. OpenCV kann Video-Dateien öffnen und die Einzelbilder daraus einlesen.
“Java is a DSL to transform big Xml documents into long exception stack traces.”
— Scott Bellware
— Scott Bellware
Dann hab ich das wohl nicht ganz verstanden.. Hab in einem Youtube Video gesehen wie jemand ein Video eingefügt hat und so dann die ganzen Parameter für die Linien als auch die Farberkennung eingestellt hat.
Wie soll ich das sonst machen ?
Wie soll ich das sonst machen ?
Ich hab versucht das aufgenommene Video einzubauen mit dem folgenden Code einzubauen:
import numpy as np
import cv2
cap = cv2.VideoCapture('video.h264')
while(cap.isOpened()):
ret, frame = cap.read()
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
cv2.imshow('frame',gray)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
cap.release()
cv2.destroyAllWindows()
Das Video aufrufen kann ich allerdings trotzdem nicht.
import numpy as np
import cv2
cap = cv2.VideoCapture('video.h264')
while(cap.isOpened()):
ret, frame = cap.read()
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
cv2.imshow('frame',gray)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
cap.release()
cv2.destroyAllWindows()
Das Video aufrufen kann ich allerdings trotzdem nicht.
Ich könnte dir das Video per Mail weiterleiten, außer du hast eine bessere Idee..
Und ja, ich kriege folgende Fehlermeldung:
C:\Users\PycharmProjects\DiplomArbeit\venv\Scripts\python.exe C:/Users/PycharmProjects/DiplomArbeit/LaneDetectionModule.py
Traceback (most recent call last):
File "C:\Users\PycharmProjects\DiplomArbeit\LaneDetectionModule.py", line 9, in <module>
img = cv2.resize(img,(480,240))
cv2.error: OpenCV(4.5.1) C:\Users\appveyor\AppData\Local\Temp\1\pip-req-build-wvn_it83\opencv\modules\imgproc\src\resize.cpp:4051: error: (-215:Assertion failed) !ssize.empty() in function 'cv::resize'
Process finished with exit code 1
Und ja, ich kriege folgende Fehlermeldung:
C:\Users\PycharmProjects\DiplomArbeit\venv\Scripts\python.exe C:/Users/PycharmProjects/DiplomArbeit/LaneDetectionModule.py
Traceback (most recent call last):
File "C:\Users\PycharmProjects\DiplomArbeit\LaneDetectionModule.py", line 9, in <module>
img = cv2.resize(img,(480,240))
cv2.error: OpenCV(4.5.1) C:\Users\appveyor\AppData\Local\Temp\1\pip-req-build-wvn_it83\opencv\modules\imgproc\src\resize.cpp:4051: error: (-215:Assertion failed) !ssize.empty() in function 'cv::resize'
Process finished with exit code 1
Ich hab es geschafft. Hab gestern durch Recherchen und auch bisschen Glück gefunden wie es funktioniert. Hab mal ein Video eingesetzt und mein Programm funktioniert bis jetzt perfekt. Nächster Schritt wäre das zusammenbauen, dann können die Tests durchgeführt werden.
Sollte ich Fragen haben, melde ich mich wieder.
Danke erstmals!
Sollte ich Fragen haben, melde ich mich wieder.
Danke erstmals!
Reicht es für die Data Collection einfach mit dem Roboter (händisch) die Strecke mehrmals durch zu fahren und so mithilfe der Kamera die Bilder in einem Ordner zu speichern?
Code für die Aufnahme wäre folgender:
und folgender Code für das Speichern der Bilder:
Code für die Aufnahme wäre folgender:
Code: Alles auswählen
import cv2
cap = cv2.VideoCapture(0)
def getImg(display= False,size=[480,240]):
_, img = cap.read()
img = cv2.resize(img,(size[0],size[1]))
if display:
cv2.imshow('IMG',img)
return img
if __name__ == '__main__':
while True:
img = getImg(True)
Code: Alles auswählen
import pandas as pd
import os
import cv2
from datetime import datetime
global imgList, steeringList
countFolder = 0
count = 0
imgList = []
steeringList = []
myDirectory = os.path.join(os.getcwd(), 'DataCollected')
# print(myDirectory)
while os.path.exists(os.path.join(myDirectory,f'IMG{str(countFolder)}')):
countFolder += 1
newPath = myDirectory +"/IMG"+str(countFolder)
os.makedirs(newPath)
def saveData(img,steering):
global imgList, steeringList
now = datetime.now()
timestamp = str(datetime.timestamp(now)).replace('.', '')
#print("timestamp =", timestamp)
fileName = os.path.join(newPath,f'Image_{timestamp}.jpg')
cv2.imwrite(fileName, img)
imgList.append(fileName)
steeringList.append(steering)
def saveLog():
global imgList, steeringList
rawData = {'Image': imgList,
'Steering': steeringList}
df = pd.DataFrame(rawData)
df.to_csv(os.path.join(myDirectory,f'log_{str(countFolder)}.csv'), index=False, header=False)
print('Log Saved')
print('Total Images: ',len(imgList))
if __name__ == '__main__':
cap = cv2.VideoCapture(1)
for x in range(10):
_, img = cap.read()
saveData(img, 0.5)
cv2.waitKey(1)
cv2.imshow("Image", img)
saveLog()
Grundsaetztlich reicht das, ja. Allerdings wuerde ich doch den Einsatz eines VideoWriters empfehlen, womit du dann Platz sparst. https://learnopencv.com/read-write-and- ... pp-python/
Und ich wuerde darueber nachdenken, ob du die Bilder wirklich resizen willst. Es ist normalerweise immer besser, Daten in der besten Qualitaet zu haben, weil man dann immer noch spaeter entscheiden kann, die zu reduzieren. Das mag im vorliegenden Fall aufgrund einer simplen Aufgabenstellung nicht soooo wichtig sein, aber vielleicht ein Tipp fuer die Zukunft.
Und ich wuerde darueber nachdenken, ob du die Bilder wirklich resizen willst. Es ist normalerweise immer besser, Daten in der besten Qualitaet zu haben, weil man dann immer noch spaeter entscheiden kann, die zu reduzieren. Das mag im vorliegenden Fall aufgrund einer simplen Aufgabenstellung nicht soooo wichtig sein, aber vielleicht ein Tipp fuer die Zukunft.
Danke für deinen Tipp __deets__. Ich habe mir die Seite angeschaut.
Mir ist aufgefallen das in meinem Code sozusagen ein Start- und Stoppbefehl fehlt. Ich würde ja in diesem Fall ein unendlich langes Video aufnehmen oder?
Mir ist aufgefallen das in meinem Code sozusagen ein Start- und Stoppbefehl fehlt. Ich würde ja in diesem Fall ein unendlich langes Video aufnehmen oder?
Ich habe ein kleines Problem beim verstehen der Funktionsweise. Um nochmal alles klarzustellen: Ich hab ein Programm für die Lienen Verfolgung was auch funktioniert. Meine Frage wäre ob ich mit diesem Programm das Fahrzeug direkt fahren lassen kann im Sinne von (erkenne die Kurve und lenke ein) oder muss ich unbedingt das Fahrzeug davor trainieren und somit Daten der Strecke "einsammeln".
Ich hoffe ich konnte mich gut ausdrücken.
LG
Ich hoffe ich konnte mich gut ausdrücken.
LG