Wiki » History » Revision 122
Revision 121 (Frédéric Blanc, 2024-11-06 14:56) → Revision 122/123 (Frédéric Blanc, 2024-11-06 15:09)
h1. Wiki !{width: 30%}https://redmine.laas.fr/attachments/download/4815/Face%20AV%20PS.jpg! !{width: 30%}https://redmine.laas.fr/attachments/download/4814/Face%20AR%20PS.jpg! {{toc}} h2. DPS version 2411 h3. Driver [[Driver DPH5005:Wiki|Driver Light DPH5005]] h3. Sous Modules DC/DC [[Wiki#DPH5005|DPH5005]] document#221 AC/DC "LCE80PS54":https://redmine.laas.fr/attachments/download/4913/Alim_LCE80.pdf RS485 [[Wiki#DFR0845|DFR0845]] h3. Fabrication [[Boitier|Boîtier Hammond1455U2201]] "Plaque de fond":https://redmine.laas.fr/attachments/download/5021/plaque%20de%20fond%20boitier%20Hammond.pdf "Sérigraphie Face AV AR":https://redmine.laas.fr/attachments/download/5023/Serigraphie%20Face%20AV%20AR%20boitier%20Hammond.pdf "Cotation Face AV AR":https://redmine.laas.fr/attachments/download/5022/cotation%20Face%20AV%20AR%20boitier%20Hammond.pdf "Fichier SVG":https://redmine.laas.fr/attachments/4916 h3. Interface USB <-> Modbus (RS485) !clipboard-202411061355-f3ozb.png! Solution au problème de ttyUSB0, il faut faire: <pre><code class="shell"> sudo apt remove brltty </code></pre> https://askubuntu.com/questions/1403705/dev-ttyusb0-not-present-in-ubuntu-22-04 h2. Modbus / RS485 isolated !clipboard-202404091540-4btca.png! https://arduino103.blogspot.com/2021/10/decoder-une-trame-rs485-loscilloscope.html h3. non isoler !clipboard-202404091414-fugem.png! !clipboard-202404081517-wbjgq.png! h4. Fusibles réarmables !clipboard-202404091611-8b8z9.png! h3. Texas Instruments ISOW14x2 Isolated RS-485 DC-DC Converter !clipboard-202404081533-dzk67.png! h3. ANALOG DEVICES LTM2881CV-5#PBF !clipboard-202404051942-kmfn5.jpg! Transceiver, RS422, RS485, 20 Mbps, 1 Driver, 1 Récepteur, 4,5 à 5.5V, 0 à 70°C, LGA-32 Code Farnell 4023829 h3. ADM2865E Power Isolated, RS-485 Transceivers !clipboard-202404041435-zyzea.png! |Code Farnell|Référence Fabricant |Fabricant / Description| |4023816 |ADM2865EBRNZ |ANALOG DEVICES Transceiver, RS422, RS485, 25 Mbps, 1 Driver, 1 Récepteur, 3 à 5.5V, -40 à 105°C, WSOIC-28| |1456395 |SM712.TCT |SEMTECH Diode TVS, SM, Bidirectionelle, 12 V, 26 V, SOT-23, 3 Broche(s)| |1515786 |BLM15HD182SN1D |MURATA Perle de ferrite, 0402 [1005 Metric], 1.8 kohm, 200 mA, BLM15H, 2.2 ohm, ± 25%| |1867958 |08053D106KAT2A |KYOCERA AVX Condensateur céramique multicouche CMS, 10 µF, 25 V, 0805 [Métrique 2012], ± 10%, X5R| |2443238 |BLM18HE601SN1D |MURATA Perle de ferrite, 0603 [1608 Metric], 600 ohm, 800 mA, BLM18H, 0.25 ohm, ± 25%| h3. Module de communication d'isolation, ADUM3201 + B0505XT TTL à RS485 !clipboard-202404231543-s8vft.png! *Attention RX sur TX* h3. DFR0845 !clipboard-202407041533-yroi0.png! !clipboard-202407121501-bz7ns.png! Ce module de transfert de signal RS485 vers UART actif et isolé est livré avec des circuits de protection tels que l'isolation de puissance et le TVS. Compatible avec la plupart des contrôleurs principaux, il présente les caractéristiques d'une vitesse de communication rapide, de performances stables et fiables, d'une sécurité élevée, etc., et peut être appliqué à divers capteurs industriels, équipements de contrôle industriel ou applications nécessitant une conversion de signal RS485. https://wiki.dfrobot.com/Gravity_Active_Isolated_RS485_to_UART_Signal_Converter_SKU_DFR0845 N° Mouser : 426-DFR0845 www.gotronic.fr Code: 37411 https://fr.farnell.com Code Commande : 3974134 h3. RS485 I2C !clipboard-202404120929-wdgmq.png! h2. XY5005E com le port 4 broches JST 1.25 ne semble pas avoir de TX, ni de RX. Il n'y a pas non plus de menu pour le chois de l'adressage !clipboard-202404081443-iygma.png! !clipboard-202404241236-ulutn.png! !clipboard-202404241234-m5crk.png! h2. XY6015L Step-Down Regulated Power Supply !clipboard-202403251011-lfrn1.png! µC AT32F421 ARM® Cortex®-M4 core Ctrl EG1163S BUCK DC-DC de Rectification synchrone 300kHz MOS NCE82H140 h2. DPS5005 !clipboard-202406181357-wvt60.png! Module d'alimentation à afficheur LCD réglable en tension de 0 à 50 Vcc et en intensité de 0 à 5 A. L'écran couleur de 1,44'' offre un affichage particulièrement détaillé et complet des informations. https://www.gotronic.fr/art-alimentation-programmable-dps5005-29294.htm h3. modification port com La vitesse de communication par défaut du port série DPS5005 est de 9 600 bauds, mais vous pouvez la modifier en alimentant l'alimentation tout en maintenant le bouton V/M1 enfoncé. Lorsque la modification est effectuée, appuyez deux fois sur le bouton « set » pour enregistrer la nouvelle configuration. h3. Firmware alternatif https://github.com/kanflo/opendps https://redmine.laas.fr/attachments/4885 h3. Brochage port com !clipboard-202407121448-7reos.png! h2. DPH5005 h3. Driver [[Driver DPH5005:Wiki|Driver Light DPH5005]] !clipboard-202406181358-4or4r.png! Module d'alimentation à afficheur LCD 1,44" réglable en tension de 0 à 50 Vcc et en intensité de 0 à 5 A. Ce module délivre un signal de sortie haute résolution réglable par paliers de 10 mV et de 1 mA. https://www.gotronic.fr/art-alimentation-programmable-dph5005-31537.htm h3. Modbus !clipboard-202404121322-qk0l1.png! voir documentation document:"protocol -english translation V1.2" |_.function code|_.Definition|_.Operation (binary)| |0x03|Read register data|Read data from one or more registers| |0x06|Write a single register|Write a set of binary data to a single register| |0x10|Write multiple registers|Write multiple sets of binary data to multiple registers| |\5=. *0x03 Read the function of the host format* | |address code|function code|Register start address |Number of register addresses n (1 ~ 32)|CRC Check code| |1 byte|1 byte|2 byte|2 byte|2 byte| |\5=. *0x03 Read function Slave returns format*| |address code|function code|Returns the number of bytes 2 * n|Register data|CRC Check code| |1 byte|1 byte|1 byte|2*n Bytes|2 byte| |\5=. *0x06 Write a single register function in host format*| |address code|function code|Register address|Register data|CRC Check code| |1 byte|1 byte|2 byte|2 byte|2 byte| |\5=. *0x06 Write a single register function from the machine to return the format*| |address code|function code|Register address|Register data|CRC Check code| |1 byte|1 byte|2 byte|2 byte|2 byte| |\6=. *0x10 Write function host format*| |address code|function code|Register start address|Number of register addresses n (1 ~ 32)|Write the number of bytes 2 * n|Register data|CRC Check code| |1 byte|1 byte|2 byte|2 byte|1 byte|2*n byte|2 byte| |\5=. *0x10 Write function slave return format*| |address code|function code|Register start address|Number of register addresses n (1 ~ 32)|CRC Check code| |1 byte|1 byte|2 byte|2 byte|2 byte| Protocol register description (single register address data for double-byte data) |name|Description|number of bytes|Decimal point|unit|Read and write|XY6015L|DPS5005|dps_modbus.py| |U-SET|Voltage setting|2|2|V|R/W|0x0000|0x0000|voltage_set| |I-SET|Current setting|2|2|A|R/W|0x0001|0x0001|current_set| |UOUT|Output voltage display value|2|2|V|R|0x0002|0x0002|voltage| |IOUT|Output current display value|2|2|A|R|0x0003|0x0003|current| |POWER|Output power display value|2|2|W|R|0x0004|0x0004|power| |UIN|Input voltage display value|2|2|V|R|0x0005|0x0005|voltage_in| |LOCK|Key lock|2|0|-|R/W|0x0006|0x0006|lock| |PROTECT|Protection state|2|0|-|R|0x0007|0x0007|protect| |CVCC|Constant voltage constant current state|2|0|-|R|0x0008|cv_cc| |ONOFF|Switch output|2|0|-|R/W|%{color:red}0x0012%|%{color:red}0x0009%|onoff| |B_LED|Backlight brightness level|2|0|-|R/W|--|0x000A|b_led| |MODEL|Product number|2|0|-|R|0x000B|model| |VERSON|Firmware version number|2|0|-|R|0x000C|version| |EXTRACT_M|Quickly bring up data sets|2|0|-|W|0x0023|extract_m| |U-SET|Voltage setting|2|2|V|R/W|0x0050|voltage_set2| |I-SET|Current setting|2|3|A|R/W|0x0051|current_set2| |S-OVP|Overvoltage protection|2|2|V|R/W|0x0052|s_ovp| |S-OCP|Overcurrent protection value|2|3|A|R/W|0x0053|s_ocp| |S-OPP|Over power protection value|2|1、2|W|R/W|0x0054|s_opp| |B-LED|Backlight brightness level|2|0|-|R/W|0x0055|b_led2| |M-PRE|The data is called to update the output|2|0|-|R/W|0x0056|m_pre| |S-INI|Power on the output switch|2|2|-|R/W|0x0057|s_ini| h3. dps_modbus.py |commande|Description| |voltage_set|Voltage setting| |current_set|Current setting| |voltage|Output voltage display value| |current|Output current display value| |power|Output power display value| |voltage_in|Input voltage display value| |lock|Key lock| |protect|Protection state| |cv_cc|Constant voltage constant current state| |onoff|Switch output| |b_led|Backlight brightness level| |model|Product number| |version|Firmware version number| |extract_m|Quickly bring up data sets| |voltage_set2|Voltage setting| |current_set2|Current setting| |s_ovp|Overvoltage protection| |s_ocp|Overcurrent protection value| |s_opp|Over power protection value| |b_led2|Backlight brightness level| |m_pre|The data is called to update the output| |s_ini|Power on the output switch| |read_all|Read data as a block, much faster than individual reads| |write_voltage_current|write voltage & current as a block| |write_all|write block| Slave Address: 1..247 ( *0: broadcast* ) Function code: see later Data: 0..252 byte(s) *CRC16-MODBUS* : see https://crccalc.com/ for code. https://github.com/LacobusVentura/MODBUS-CRC16 h3. test commande h4. XY6015L sur /dev/ttyACM0 Broadcast Power ON <pre><code class="shell"> echo -ne "\x00\x06\x00\x12\x00\x01\xE9\xDE" > /dev/ttyACM0 </code></pre> Broadcast Power OFF <pre><code class="shell"> echo -ne "\x00\x06\x00\x12\x00\x00\x28\x1E" > /dev/ttyACM0 </code></pre> sur /dev/ttyUSB0 Broadcast Power ON <pre><code class="shell"> echo -ne "\x00\x06\x00\x12\x00\x01\xE9\xDE" > /dev/ttyUSB0 </code></pre> Broadcast Power OFF <pre><code class="shell"> echo -ne "\x00\x06\x00\x12\x00\x00\x28\x1E" > /dev/ttyUSB0 </code></pre> h4. DPS5005 or DPH5005 *BAUD Max 9600* sur /dev/ttyACM0 Broadcast Power ON <pre><code class="shell"> echo -ne "\x00\x06\x00\x09\x00\x01\DE\xE9" > /dev/ttyACM0 </code></pre> Broadcast Power OFF <pre><code class="shell"> echo -ne "\x00\x06\x00\x09\x00\x00\x1E\x28" > /dev/ttyACM0 </code></pre> DPS07 Power OFF <pre><code class="shell"> echo -ne "\x07\x06\x00\x09\x00\x00\xAE\x59" > /dev/ttyACM0 </code></pre> sur /dev/ttyUSB0 Broadcast Power ON <pre><code class="shell"> echo -ne "\x00\x06\x00\x09\x00\x01\DE\xE9" > /dev/ttyUSB0 </code></pre> Broadcast Power OFF <pre><code class="shell"> echo -ne "\x00\x06\x00\x09\x00\x00\1E\x28" > /dev/ttyUSB0 </code></pre> h3. notice presser [SW] pendant 2s pour accéder aux paramètres !clipboard-202404041503-e5ifh.png! h2. GUI Python h3. venv — Création d'environnements virtuels <pre><code class="shell"> $ python3 -m venv venv </code></pre> Pour activer l'environnement, exécutez <pre><code class="shell"> source venv/bin/activate </code></pre> <pre><code class="shell"> . venv/bin/activate </code></pre> sous Windows <pre><code class="shell"> env\Scripts\activate.bat </code></pre> Vous devrez « quitter » ou « désactiver » votre environnement virtuel à l'aide de la commande <pre><code class="shell"> deactivate </code></pre> https://docs.python.org/fr/3/library/venv.html h3. pyqt5 <pre><code class="shell"> pip3 install pyqt5 --config-settings --confirm-license= --verbose </code></pre> https://stackoverflow.com/questions/73714829/pip-install-pyqt5-it-cannot-go-on h3. XY6015L_pyGUI lancement de l'interface <pre><code class="python"> python dps_GUI_program.py </code></pre> !clipboard-202404041117-w53xm.png! configuration du port com le port série peut être corrigé en modifiant le paramètre "port_set" dans "dps5005_limits.ini". <pre><code class="shell"> [SectionZero] The parameters below limit the code from incorrectly transmitting extreme values entered by the user: if threshold exceeded value defaults to zero: This file may be adapted for other versions of 'DPSxxxx' power supplies: [SectionOne] #leave empty "" for automatic port scanning or set serial port e.g. "/dev/cu.wchusbserial1410" or "/dev/ttyUSB0": port_set: "/dev/ttyACM0" # #The parameters below limit the code from incorrectly transmitting extreme values entered by the user: #if threshold exceeded value defaults to zero: ... </code></pre> h2. SCPI h3. SCPI parser À propos de l'analyseur SCPI La bibliothèque SCPI Parser vise à fournir une capacité d'analyse des commandes SCPI côté instrument. Toutes les commandes sont définies par leurs modèles, par exemple : "STATus:QUEStionable:EVENt?". Les codes sources sont publiés avec une licence BSD simplifiée open source. La bibliothèque d'analyseurs SCPI est basée sur ces normes: *SCPI-99 IEEE 488.2-2004* https://github.com/j123b567/scpi-parser h2. Sources https://profimaxblog.ru/dps_update/ https://www.circuitstate.com/tutorials/what-is-rs-485-how-to-use-max485-with-arduino-for-reliable-long-distance-serial-communication/ http://xj900diversion.free.fr/bus/I2C%20-%20RS-485%20adapter.htm https://github.com/AntaresAdroit/RDTech_PS_Comm https://github.com/lambcutlet/DPS5005_pyGUI https://github.com/kbs3056/XY6015L_pyGUI