Jump to content

photron

Administrators
  • Content Count

    2489
  • Joined

  • Last visited

  • Days Won

    1

photron last won the day on November 19

photron had the most liked content!

Community Reputation

1 Neutral

About photron

  • Rank
    Tinkerforge Staff
  1. Firmware: LED Strip Bricklet 2.0 2.0.3 Fix set-led-values length check to allow setting the last (6143th) LED as well Fix streaming logic of get-led-values for length above 60 LEDs Download: LED Strip 2.0
  2. Firmware: LED Strip Bricklet 2.0 2.0.3 set-led-values Längenprüfung korrigiert, um das Setzen der letzen (6143te) Einzel-LED zu erlauben Streaming-Logik in get-led-values für Längen über 60 Einzel-LEDs repariert Download: LED Strip 2.0
  3. Nach 5 Minuten google würde ich da so heran gehen: Es gibt Open Source CANopen Stacks, zum Beispiel https://github.com/CANopenNode CANOpenNode hat ein Driver Model für die CAN Hardwareeinheiten verschiedener Mikrocontroller und kann mit CANopenSocket auch auf Linux laufen. Dem würde ich versuchen, das CAN Bricklet als CAN Hardwareeinheiten hinzuzufügen.
  4. Über die Planung ist es bisher nicht hinausgekommen. Vielleicht können andere von ihren Erfahrungen berichten. Frage am Rande: Willst du ein existierendes CANopen Gerät abfragen/steuern, oder selbst ein neues CANopen Gerät bauen?
  5. The set_voltages_callback_configuration function is new and not part of Python API bindings version 2.1.23. It will be part of version 2.1.24 that will be released this week.
  6. Es gibt zwei Varianten von Base58: https://en.wikipedia.org/wiki/Base58 Wir verwenden die Flickr Variante, die meisten Online Tools scheinen aber die Bitcoin Variante zu verwenden. 6DbKt8 dekodiert zu 0x31 0x10 0xb1 0xdc Ich kann auf Anhieb kein Online Tool finden, dass die Flickr Variante nutzt. Ich habe gerade ein kleines Python Script zusammenkopiert, dass die Flickr Variante dekodiert: $ python3 base58decode.py 6DbKt8 base58: 6DbKt8 decimal: 3702591537 hexadecimal: 0xdcb11031 bytes (little endian): 0x31 0x10 0xb1 0xdc $ python3 base58decode.py b1Q base58: b1Q decimal: 33688 hexadecimal: 0x8398 bytes (little endian): 0x98 0x83 0x0 0x0 base58decode.py
  7. Nach meinem Wissen ist das eine reine Geschmacksfrage.
  8. Problem wurde per Email geklärt. Bricklets waren vollständig ungeflasht und wurden durch neue geflashte Bricklets ausgetauscht.
  9. All unsere API Bindings für die verschiedenen Programmiersprachen nutzen intern unser TCP/IP Protokoll. Daher kannst du dir irgendeins unserer API Bindings ansehen als Beispiel dafür wie das TCP/IP Protokoll zu nutzen ist. Aber kannst du auf dem cRIO nicht einfach unsere .NET basierten LabVIEW Bindings einsetzen? Oder unterstützt der cRIO .NET nicht?
  10. Es sollte prinzipiell jeder LTE USB Stick funktionieren. Wenn du einen zur Hand hast, dann probier das einfach mal aus. In dem Sinne unterscheidet sich ein UMTS USB Stick und ein LTE USB Stick aus der Sicht des RED Bricks nicht.
  11. Okay, wenn du also schon weißt, dass es vor dem Hinzufügen von SQLite und dem Solid State Relay besser war, dann sollte es nicht so schwer sein das Problem zu finden. Hast du deinen Code unter Versionskontrolle (git, svn, hg ...)? Sprich hast du noch eine alte Version deines Programs, bevor das Problem aufgetreten ist? Dann teste diese alte Version jetzt noch mal, nur um sicher zu gehen, dass das Problem durch Änderungen an deinem Programm entstanden ist und nicht durch irgendetwas anderes was sich in der Zwischenzeit geändert hat. Wenn das Problem in deinem Programm ist, dann sollte die alte Version jetzt auch noch gut laufen. Wenn eine alte Version des Programm besser läuft, dann muss es an etwas liegen, dass du in deinem Programm geändert hast. Es mag an SQLite liegen, auch wenn dein Betreuer das für unwahrscheinlich hält. Solange du nicht beweisen kannst, dass SQLite nicht das Problem ist, solltest du das nicht einfach so ausschließen. Es man nicht SQLite im allgemeinen sein, aber vielleicht verwendest du SQLite in einer ungünstigen Weise. Das kannst du testen in dem du in deinem Programm den SQLite Teil mal totlegst, bzw. den Solid State Relay Teil. Damit solltest du herausfinden können wo das Problem entsteht. Du baust im Prinzip eine alte schnelle Version des Programms Schritt für Schritt auf die aktuelle langsame Version um und testet nach jedem Schritt. Auf dem Weg solltest du das Problem finden.
  12. Okay, dann kannst du dein Programm mit einem Profiler betrachten, um zu sehen wo das Programm seine Zeit verbringt: https://docs.python.org/3.7/library/profile.html Das erste wo nach ich im Code schauen würde, ist ob du Schleifen hast, die irgendetwas viel häufiger tun als sie müssten: Nach diesem Muster z.B.: while True: ptc_bricklet.get_temperature() Der Code fragt mit voller Geschwindigkeit die Temperatur ab, mehrere tausende male pro Sekunde. So schnell ändert sich die Temperatur aber nicht. Es würde auch vollständig reichen die Temperatur nur jede Sekunden anzufragen: while True: ptc_bricklet.get_temperature() time.sleep(1) Das spart enorm CPU Last.
  13. So ins Blaue antworten ist schwer. Zeig doch mal dein Python Programm vor.
  14. Zu 1: Der Chip Type sollte eigentlich immer von Verkäufer der LED Strips angegeben sein. Unsere LED Strips sind z.B. WS2812B. Beim Channel Mapping ist das etwas komplizierter, denn das ist im Zweifelsfall auch zwischen gleichen Chip Typen nicht identisch. So ein WS2812B hat 3 Kanäle an denen jeweils eine LED angeschlossen ist. Es muss nicht immer der erste Channel Rot sein. Das kann zwischen Herstellern unterschiedlich sein. Daher sagt die Doku "typischerweise". Da kommst du um ausprobieren nicht herum. Das einfachste ist RGB als Channel Mapping zu wählen, dann z.B. (255, 0, 0) auf die erste LED zu setzen. Wenn dann die LED blau leuchtet, dann weißt du, dass das richtige Channel Mapping auf der ersten Stelle Blau hat. So kannst mit 2-3 Teste das richtige Channel Mapping finden. Zu 2: Muss ich mir anschauen, hört sich aber komisch an, da ist potentiell was nicht richtig.
  15. That's strange, that dpkg doesn't complain like this when you tried to install the amd64 version. Anyway, we currently don't provide a precompiled brickd for arm64. Therefore, compiling from source is the best option you currently have for arm64.
×
×
  • Create New...