====== Thermoprinter ======
===== General info =====
Here I will post the information and progress about my diploma thesis. Shortly describing the project, it should be portable thermoprinter with bluetooth/USB communication, supporting multiple protocols.
This type of printer can be used with POS for printing recipes or with scientific equipment for printing reports.
===== Assets =====
What I have:
* Thermoprinter head
* STM32-Nucleo eval board
* BLE module
* All needed connectors that fit thermoprinter head
* Stepper motor driver breakout module
* Li-Ion batteries and holders
* Li-Ion battery protection and charging circuits
* Other small parts, like voltage regulators, LEDs, buttons, descreet elements
What is missing:
* Some transistors
* Proper stepper motor driver IC
* STM32 programming experience
===== Plans =====
* Attach assembled circuits to print head and to eval board
* Test printing
* Implement subset of ESCPOS protocol
* Change firmware to print predefined lines via BT (implement RAW proto)
* Add power saving mode into firmware
* Find suitable Li-Ion battery management circuit
* Find suitable voltage regulators
* Test eval circuit with battery
* Design enclosure
* Redesign hardware in Diptrace if possible
* Final hardware design
* Order PCB manufacturing
* Solder device PCB
* Implement subset of PJL protocol
* Write report
===== In progress =====
* Write firmware to drive stepper motor
* Should use acceleration/deceleration from datasheet (count lines in queue to calculate speed profile or decelerate after all lines are printed, anyway some space between documents is needed)
* Should be interrupt based (to allow time for calculations, data sending to the printer head and printing)
* Should follow datasheet guide on printing start sequence (pull paper, then push to allow more or less constant speed printing)
* Write firmware to print predefined lines
* Attach stepper motor driver to motor and eval board
* Test assembled circuits with oscilloscope and compare with simulation
===== Done =====
* Connect BT module to eval board
* http://www.ebay.ca/itm/332248543230?ssPageName=STRK%3AMEBIDX%3AIT&fromMakeTrack=true
* http://www.ebay.ca/itm/CC2540-Bluetooth-Module-Serial-Communication-Slave-Passthrough-Bluetooth-4-0BLE/122105313605?_trkparms=aid%3D222007%26algo%3DSIM.MBE%26ao%3D1%26asc%3D20140620091118%26meid%3D92d4a008849844c5918b15f518ffde3e%26pid%3D100005%26rk%3D3%26rkt%3D6%26sd%3D272661306345&_trksid=p2047675.c100005.m1851
* https://www.futurashop.it/image/catalog/data/Download/RF-BM-S02.pdf
* http://arduino.ru/forum/apparatnye-voprosy/bluetooth-40-ble-cc2540-cc2541-rf-bm-s02-kak-podklyuchit-k-arduino
* https://docs.google.com/file/d/0ByLk3af9VgyybndqVFBWRlM5aGM/view
* Write firmware to establish BT communication between PC/Smartphone and eval board
* https://www.youtube.com/watch?v=PKUjaDzUpa4
* https://github.com/znfgnu/kwatch-firmware
* http://spectrumdig.blogspot.com.ee/2015/04/rf-bm-s02-pinouts-cc2540cc2541.html
* http://forum.easyelectronics.ru/viewtopic.php?f=6&t=11794&start=25
* http://en.pudn.com/downloads525/sourcecode/embedded/detail2175724_en.html
* http://processors.wiki.ti.com/index.php/CC254X_WITH_EXT_MCU
* http://processors.wiki.ti.com/index.php/SerialBLEbridge_V_1.4.1
* https://community.st.com/thread/36837-uart-ctsrts-hal-based-example-code-for-stm32f4xx-device
* https://bluekitchen-gmbh.com/btstack-port-for-stm32-f4-discovery-board-with-cc256x/
* Find stepper motor driver
* http://www.ti.com/lit/ds/slvsb19d/slvsb19d.pdf
* https://www.oomipood.ee/kataloog/farnell/toode?sku=2115234
* Assemble stepper motor driver breakout board
* Assemble pulse length protection circuit
* https://www.oomipood.ee/kataloog/tme/toode?sku=HEF4538BT.652&t=hef4538
* https://www.tme.eu/gb/Document/fd06f66fc618772a331feaa9f315adf8/HEF4538BT.652.pdf
* https://www.oomipood.ee/kataloog/tme/toode?sku=74AHC1G00GV.125&t=74ahc1g00
* https://www.tme.eu/gb/Document/9510631cc4884596c0243e91d551be16/74AHC1G00GV.125.pdf
* Assemble other print head driving circuit
* https://assets.nexperia.com/documents/data-sheet/74HC_HCT595.pdf
* https://www.oomipood.ee/kataloog/farnell/toode?sku=8649820
* http://www.farnell.com/datasheets/274342.pdf
* https://www.oomipood.ee/product/bc847b_mbr_bc847b_si_n_50v_0_1a_0_25w_1f_smd?q=bc847b
* https://assets.nexperia.com/documents/data-sheet/BC847_SER.pdf
* Assemble temperature and voltage protection circuit
* https://www.oomipood.ee/product/lm393ad_lm393ad_comparator_dual_smd_soic8_393?q=lm393
* http://www.jameco.com/Jameco/Products/ProdDS/902910.pdf
* https://www.oomipood.ee/product/bc857b_mbr_bc857b_si_p_50v_0_1a_0_25w_3f_smd?q=bc857b
* https://assets.nexperia.com/documents/data-sheet/BC856_BC857_BC858.pdf
==== As SPICE simulations course work ====
* First hardware design (schematic and PCB)
* Protection SPICE simulation
==== 6.09.2017 ====
* Filled this page with information
* Searched for documents and forums with information about parts, connecting them and writing firmware for controlling them
==== 8.09.2017 ====
* Soldered wires to BLE module.
* Read BLE module datasheet
* Read eval board datasheet
==== 10.09.2017 ====
* Installed several IDEs for STM32 and selecting most convenient
* Researching code examples for controlling USART with hardware flow control (BLE module requires HW flow control)
* Researching code examples for controlling GPIO (button needed to initiate BLE module pairing with smartphone), handling internal and external interrupts (let MCU conserve energy in sleep mode and only wake up to process incoming data)
* Testing IDEs (emBitz, emIDE, CrossStudio, SEGGER Studio)
==== 11.09.2017 ====
* Testing IDEs (IAR, Keil, AtollicStudio, SystemWorkbench, STM32CubeMX)
* Researching code examples for controlling MCU clocks (MCU has several internal and external clock sources, several buses that can be fed from different clock sources, as well as almost each feature can be fed from different clock sources and there are clock dividers and multipliers between them to set required frequency)
* Successfully tested USART example with SystemWorkbench IDE and selected it with STM32CubeMX configurator for further use.
==== 13.09.2017 ====
* Successfully tested interrupt based GPIO code to control USER button and LED on eval board
==== 14.09.2017 ====
* Found and researched examples of using UART hardware flow control, required for BLE module
==== 16.09.2017 ====
* Compiled USART examples into a somewhat working code. HAL USART driver is not suitable due to interlocking issue described [[https://community.st.com/thread/9360|here]]. I will have either to rewrite HAL portion of UART driver or reimplement UART communication myself. At the moment code should read byte by byte and immediately copy that into the second UART port. However, it can either send or receive at once, so every odd byte is lost. Perhaps using DMA is the one of the best solutions. Communication issues can be seen on the screen shot, where pre-last lines have missing symbols and last line was sent using doubled symbols.
* BLE module UART communication receive and transmit functions are implemented within different GAP services, so no ready made BLE serial port android applications can work with it. I can only send or only receive, since application connects to a single service at once.
{{:electronics:img_1191.jpg?640|BLE modeule connected to eval board}} {{:electronics:capture.png?640|Communication screenshot}}
Screen shot explanation: READY is printed, when eval board is started, CONNECTING... is printed, when USER button on eval board is pressed and BLE module is enabled to broadcast continuously to allow connection from other devices, TTM:xxx are module informational messages and all other text is sent from android based mobile phone using BLE communication application.
==== 18.09.2017 ====
* Rewritten code without handling UART interrupts with HAL and without DMA. Now every character is transmitted correctly back and forth. Tested with several android BLE apps. Also added the place in the code where printer commands and BLE module communication to be parsed.
{{:electronics:capture1.png?640|}}
==== 20.09.2017 ====
* Ordered missing components required for protection circuits and stepper motor driver
==== 21.09.2017 ====
* Got my stepper motor driver returned by friend who borrowed it for his CNC cutter, just to find out, it requires minimum of 12 V power supply for motor. This renders it unusable, since printer head allows no more than 8.5 V, which is fully charged 2S Li-Ion battery pack voltage. Will wait for ordered parts and make my own breakout board. Fortunately, I have ordered 2 ICs and will not have to take the breakout board apart for the final hardware.
==== 27.09.2017 ====
* Received stepper motor driver ICs, multivibrators, MOSFETs, transistors and logic gates, that were missing.
{{ :electronics:img_1244.jpg?nolink&600 |}}
* Should finish stepper motor driving code
* Should now be able to assembly stepper motor driver breakout board (smth. like Polulu)
* Should now be able to assembly protection circuits and test them with oscilloscope
==== 4.10.2017 ====
* Finished soldering available breakout boards (shift register for managing heat elements blocks, battery voltage switch to supply stepper motor and heat elements, and pulse length protection), 5.09.2017 remaining ordered components should arrive
{{ :electronics:img_1253.jpg?nolink&600 |}}
{{ :electronics:img_1252.jpg?nolink&600 |}}
{{ :electronics:img_1251.jpg?nolink&600 |}}
==== 5.10.2017 ====
* Performed research on different printing protocols (http://hacking-printers.net/wiki/index.php/Fundamentals). Basically 3 communication layers exist:
* Physical (networked/wire/wireless connection and protocols)
* Printer job management (spooling, settings, etc.)
* Printer control (print data, settings, status)
* Since existing BLE module allows only low speed communication and USB does not need network, then no network protocol support will be implemented for the prototype.
* http://hacking-printers.net/wiki/index.php/Port_9100_printing
* Links about printer control:
* https://qz.io/wiki/What-is-Raw-Printing
* https://www.codeproject.com/Messages/3286786/Re-use-esc-pos-command-to-control-printer.aspx
* http://sparkag.com.br/wp-content/uploads/2016/06/ESC_POS-AK912-English-Command-Specifications-V1.4.pdf
* http://www.colorpilot.com/emfprinter_pos.html
* https://play.google.com/store/apps/details?id=com.loopedlabs.escposprintservice
* https://www.unc.edu.ar/sites/default/files/Tickeadoras-FAQ-ESCPOS.pdf
* https://stackoverflow.com/questions/44107254/esc-pos-command-esc-for-printing-bit-image-on-printer
* https://metacpan.org/pod/Printer::ESCPOS::Manual
* http://search.cpan.org/~shantanu/Printer-ESCPOS-1.006/lib/Printer/ESCPOS.pm
* https://www.pos-x.com/download/escpos-programming-manual/
* https://python-escpos.readthedocs.io/en/latest/
* http://wiki.microinvest.su/index.php?title=ESC/POS_%D0%BA%D0%BE%D0%BC%D0%B0%D0%BD%D0%B4%D1%8B_%D0%BF%D1%80%D0%B8%D0%BD%D1%82%D0%B5%D1%80%D0%B0
* http://www.starmicronics.com/support/mannualfolder/escpos_cm_en.pdf
* https://mike42.me/blog/what-is-escpos-and-how-do-i-use-it
* http://content.epson.de/fileadmin/content/files/RSD/downloads/escpos.pdf
* https://github.com/python-escpos/python-escpos
* https://github.com/mike42/escpos-php
* https://ru.wikipedia.org/wiki/ESC/P
* https://www.cups.org/doc/postscript-driver.html
* http://hacking-printers.net/wiki/index.php/PostScript
* https://en.wikipedia.org/wiki/Open_XML_Paper_Specification
* https://en.wikipedia.org/wiki/Portable_Document_Format
* https://en.wikipedia.org/wiki/HP-GL
* https://en.wikipedia.org/wiki/ESC/P
* http://www.undocprint.org/formats/page_description_languages/qpdl
* http://www.undocprint.org/formats/page_description_languages/prescribe
* http://www.undocprint.org/formats/page_description_languages/zjstream
* http://www.undocprint.org/_media/formats/page_description_languages/pcl_xl_2_0_technical_reference_rev2_2.pdf
* http://hacking-printers.net/wiki/index.php/PRET
* http://hacking-printers.net/wiki/index.php/PCL
* http://www.hp.com/ctg/Manual/bpl13210.pdf
* http://www.pltviewer.com/
* http://cstep.luberth.com/hpgl.htm
* http://www.sxlist.com/techref/language/hpgl/commands.htm
* http://www.maths.usyd.edu.au/u/psz/ps.html
* http://www.undocprint.org/_media/formats/page_description_languages/pcl5_comparison_guide_addendum.pdf
* http://www.undocprint.org/_media/formats/page_description_languages/pcl5_comparison_guide.pdf
* http://www.undocprint.org/_media/formats/page_description_languages/pcl5_quick_reference.pdf
* http://h10032.www1.hp.com/ctg/Manual/bpl13207
* http://h10032.www1.hp.com/ctg/Manual/bpl13208.pdf
* Links about printer job management
* http://www.undocprint.org/formats/printer_control_languages/ejl
* http://www.undocprint.org/formats/printer_control_languages/pjl
* It seems to be pretty large work to implement many standards and even subsets, so I will implement ESC/POS for the start and then PJL which will allow extension of supported standards later.
* General information for implementing ESC/POS or PCL
* https://en.wikipedia.org/wiki/Point_(typography)
* Performed research about full-featured bluetooth modules:
* https://blog.miguelgrinberg.com/post/a-cheap-bluetooth-serial-port-for-your-raspberry-pi
* http://smoothieware.org/bluetooth-serial
* https://www.ittgroup.ee/et/juhtmevaba-side-moodulid/999-bluetooth-serial-moodul-hc-05.html
* https://forum.arduino.cc/index.php?topic=370123.0
* https://www.itead.cc/wiki/Serial_Port_Bluetooth_Module_(Master/Slave)_:_HC-05
* https://www.itead.cc/serial-port-bluetooth-module-master-slave-hc-05.html
* http://lobotryasy.net/learning_bluetooth_part_1.php
* http://robotclass.ru/articles/bluetooth-hc-05-06/
* http://we.easyelectronics.ru/part/rabota-s-bluetooth-modulem-hc05.html
* https://www.oomipood.ee/product/cz_hc_05_bluetooth_moodul_hc_05
* https://www.aliexpress.com/wholesale?catId=0&initiative_id=SB_20171005022645&SearchText=hc-05
* http://forum.amperka.ru/threads/%D0%B2-%D1%87%D1%91%D0%BC-%D1%80%D0%B0%D0%B7%D0%BD%D0%B8%D1%86%D0%B0-%D0%BC%D0%B5%D0%B6%D0%B4%D1%83-hc-05-%D0%B8-hc-06.4392/
* http://we.easyelectronics.ru/GYUR22/bluetooth-modul-hc06-s-dx.html
* http://byron76.blogspot.com.ee/2011/09/one-board-several-firmwares.html
* http://lobotryasy.net/learning_bluetooth_part_2.php
* http://cxem.net/arduino/arduino63.php
* http://privateblog.info/arduino/bluetooth-modul-jy-mcu/
* http://www.ebay.com/itm/HC-05-HC-06-HC-08-HC-09-Wireless-Bluetooth-Transceiver-Module-RS232-TTL-/351238472386
* https://ru.aliexpress.com/store/product/SH-HC-08-CC2541-Bluetooth-4-0-BLE-to-UART-Transceiver-Module-with-Transparent-Serial-Port/1497906_32392960671.html
* http://www.dx.com/p/hc-08-bluetooth-v4-0-serial-adapter-module-green-385719
* http://www.microchip.su/showthread.php?t=17089
* http://www.avislab.com/blog/hc-07/
* https://www.banggood.com/HC-09-Slave-Bluetooth-Serial-Module-Compatible-With-HC-06-Module-p-973854.html
* https://www.fasttech.com/product/1576000-jy-mcu-hc-09-bluetooth-wireless-serial-port-module
* https://www.google.ee/search?q=CZ-HC-05&ie=utf-8&oe=utf-8&client=firefox-b&gfe_rd=cr&dcr=0&ei=RwXWWe7aI8aDyAWUl5jgBQ
* To summarize, there is a family of chinese HC-0X BT modules, some of them are master/slave-only firmware locked. HC-08 is BLE, HC-09 is latest BT. HC-07 and HC-09 might have difficult to use, so HC-05 might be considered for purchase. As much as delivery period from China is totally random, I will continue to use current BLE module, and in case BT module will arrive timely, I will replace the BLE module.
* Received remaining ordered parts
==== 6.10.2017 ====
* Finished soldering stepper motor driver breakout board and printer head sensors breakout board. Temperature and voltage protection circuit remain unsoldered.
{{ :electronics:img_1249.jpg?nolink&600 |}}
{{ :electronics:img_1250.jpg?nolink&600 |}}
==== 7.10.2017 ====
* Finished soldering temperature and voltage protection circuit
{{ :electronics:img_1248.jpg?nolink&600 |}}
==== 24.10.2017 ====
* Reinstalled Altium CircuitMaker to make it work again. Eventually old installation stopped working by consuming CPU resources and not showing any UI at startup. Trying to correct the problem, I have performed extensive research and as a last resort tried to reinstall. However installer refused to install the software into the non-empty folder, so I had to remove old version and install new from scratch.
* Found potential issue with shift register circuit. As it should drive the printer head directly, the output of shift registers should be clearly defined High or Low level. However with using Output Enable input I can only get Z-state on outputs between values change and that can influence unpredictably on the printout. As a result, I have added pull-up resistors to tie the outputs to the High level, when not printing.
==== 25.10.2017 ====
* Selected and ordered non-BLE bluetooth module HC-05 and BK3231. BK3231 is cheaper and has better organized AT command communication, but it has slave only firmware. On the other hand HC-05 is a master/slave programmaticaly selectable unit, but AT communication is a bit tricky. There is also a possibility to change the firmware on a HC-05 modules to a commercial grade RN42 module firmware.
* Some more information on the BT modules:
* http://lobotryasy.net/bluetooth_spp_c.php
* http://radiokot.ru/circuit/digital/pcmod/39/
* http://www.instructables.com/id/3-Bluetooth-HID-Module-HC05-With-RN42-Firmware/
* http://www.instructables.com/id/Upgrade-Your-3-Bluetooth-Module-to-Have-HID-Firmwa/
* Tested battery voltage switch circuit. Outcome shows, that it works as expected:
{{:electronics:vhefb6v0.png?nolink|VH enable with feedback 6.0V}} {{:electronics:vhefb8v4.png?nolink|VH enable with feedback 8.4V}}
==== 5.11.2017 ====
* Tested battery voltage monitor circuit and overheat monitor circuit. As designed, battery voltage monitor trips when battery voltage declines below 6.0 V. Temperature monitor circuit trips at voltage level below 1.25 V, which corresponds to 65 C for NTC thermistor integrated into thermoprinter head.
{{:electronics:bcwi.png?nolink|Battery voltage monitor trips at 6.0 V}} {{:electronics:traps.png?nolink|Overheat protection trips at 1.25 V corresponding to 65 C}}
==== 12.11.2017 ====
* Received HC-05 Bluetooth transceivers:
{{:electronics:img_1329.jpg?nolink|}}
* Published firmware on GitHub: https://github.com/dmmedia/Thermoprinter
* Firmware framework borrowed from [[https://github.com/MarlinFirmware/Marlin|Marlin 3D printers firmware]].
* Conversion from AVR to STM32 and adapting for thermoprinter is in progress (removing more than 1 stepper motor support, replacing analogue sensors and replacing endstops with bistate sensors)
==== 21.11.2017 ====
* Received SPP-C Bluetooth transceivers
* Tested both HC-05 and SPP-C modules. HC-05 modules need to be powered on in special sequence to boot into AT command mode, while SPP-C modules are always in AT mode, while not connected to other Bluetooth device. Both modules do not require hardware flow control. Many android software applications support traditional Bluetooth serial communication.
* Firmware code is mostly ported from AVR to STM32 platform and unneeded functionality removed. At the moment ADC code left partially ported.
==== 08.03.2018 ====
* Counting printable bits to optimize the number of simultaneously driven 64-bit blocks turned out to be a combinatorial task or [[https://en.wikipedia.org/wiki/Partition_problem|Partition problem]]. More specifically a [[https://en.wikipedia.org/wiki/Bin_packing_problem|Bin packing problem]]. Generally speaking, the resulting count of sums of simultaneously driven blocks will be not more than optimal count plus 2 if I would use First fit decreasing or Best fit decreasing algorithms.
* Counting bits themselves turned to be another well-known problem named [[https://en.wikipedia.org/wiki/Hamming_weight|Hamming weight]]. Need to check whether STM32 has any special support for bit counting.
==== 02.04.2020 ====
* Thought that porting Marlin 3D printer firmware was bad idea, since the functionality is totally different and Marlin implementation is not brilliant. Will start from scratch and implement stepper motor advance on user button press and hold. Motor will advance with the lowest speed described in the thermal head manual. Next step will add accelleration and deceleration.