This project was created to help people who would use a C245 and C470 JBC handle and cartridge without the expensive controller. There is some project on the internet what provides a solution. My first steps was also to find a complete method or solution. Here is some already existing projects.
There are some basic problems with those solution. I don't have an Arduino and I don't want to use that.
I wanted to...
- Use PID control to provide stable temperature on the end of the tip ✔️
- Use LCD display that I have bought long-long time ago ✔️
- Build the HW with components that I already had ✔️
- Implement sleep function ✔️
- Make 3D printed housing with individual design ✔️
- Have individual PCB design ✔️
- Use encoder as user input ✔️
- Use SPI thermocouple interface IC ✖️
So, to sum up the above mentioned points there is no universal solution. Okay, Unisolder would be the best choice, but I only want a JBC 470 compatible controller. I can't flash PICs, and the schematic is overcomplicated. (Nevertheless, I know that is an UNIversal SOLution for any types of solDERing irons...) So I have decided that I will create my own project. The main goal was to create a good and cheap alternative, and during the prototyping I would have to learn (PID, programming, signal processing, a little power electronics, Matlab, etc).
Firstly I wanted to build a proper working proto HW. On the net, there are a lots of true and false informations about the cartridge. There are 2 type of people: The first typed are saying the common conductor is the red wire, and the second says green. Okay but what is the truth?
There was a person who mentioned on some electronics forum that the green is the common conductor, this is the outer sleeve of the cartridge what is supposed to be grounded (ESD safety). And there are a lots of people who says the common conductor is the pin (the end of the tip). At that point i was absolutely confused...
I found an article on the web about these JBC cartridges. According to that document the heating element is between red(common, heater1 and TC+)[2] and blue(heater2)[5] and the thermocouple is between red(heater1 and TC+)[2] and green(TC-)[1]. *[Connector pin number on the soldering iron] To make this statement absolutely true, I have performed some basic measurements on the tip.
- The heater is around 2-3Ohm sightly depending on the ambient temperature. For me that was ~2,5Ohm.
- According to the sketch above, I heated up the tip with an external heat source (cigarette lighter, another soldering iron). When the tip is around 2-300°C the thermocouple generates 4-6mV. Measuring DC voltage between red and green with a multimeter, you need to see something like that values.
When you measure at 2-300°C between blue and green (heater2 and TC-) you can measure the series resistance of the TC and heater coil. When you put the positive cable on the blue and the negative on the green you need to measure higher(?) value compared with the reversed measurement (positive on the green and negative on the blue). If the difference is recognizable and we can be sure about that is not a measuring error, we can state that the first supposition is the reality. When you are skeptic about the right consequences you can repeat the measurements with the second theorem (I did)...
I only use AVRs and STM32s, so there wasn't a question what I will use. The proto board was built around an STM32L476-Nucleo board. At this point I just wanted to be sure about the possibilities. Will it work? Can it? It need to be find out with a possible less effort.
To contolling the LCD with a proper refresh rate STM32's computing performance was requred. The MCU is responsible for contolling the LCD, computing PID, reading TC via SPI, swithing on and off the sleep function, handling the encoder. The timing is provided by a zero crossing detector.
After the quick prototype I earned some experience with the system. In this section you can read my opinion with the parts.
I have a lot of experience with the STM32F446RET microcontroller. In the demo software I used this type, and I think it need to be left for the project. It can be bought under 10$.
The demo hardware had a very simple zero crossing detector circuit. In the project it was replaced by an LM311 comparator which is not a single opa. It have a transistor on its output so driving 10mA is not problem.
To aid my work I used TINA simulation to design a zero-crossing detector. This is a fedbacked comparator what provides rising and falling edges. The isolated DCDC converter and the optotransistor provides the galvanical isoaltion from the other parts of the schematic. A full-bridge rectifier make the sine wave to be only above the zero. The comparator sets its output according to the its imputs. If the negative input is higher the output will be 'GND' or local negative potential, and if the positive input is higher the output will be on local +VCC (~32V). The other side of the optotransistor there is an open collector output that goes to an interrupt input what is pulled up internally to the MCU +VCC potential(3,3V).
Note: This logic is reversed the original signal, but we can handle it from the sw.
The theorem is the following:
We work in 11 half waves cycles. One of them is for reading out the TC temperature data. Until the reading we need to switch off the power on the heating element because currents on the common wire can easily influence the TC's ultra sensitive signal. The first half wave of the 11 is only for the temperaure reading. After the reading(s) from the second half wave to the eleventh we can control the half waves according to the PID. We need to normalize the output "duty" to 10% steps, because we have 10 half wave and we only can switch on for integer halfwaves. So the duty is can be calculated by ONhw/11 where ONhw is the half waves when the output is ON and it goes from 0 to 10. So the effective duty is minumum 0%(obviously) and the maximum is 90%. Nevertheless, don't worry, this soldering iron can be heated up from room temperature to red glowing within 15 seconds if you are not careful with 3/11 duty. I wasn't careful enough... :(
In the original solution there are 2 serially connected MOSFET. To save money I designed my DIY station with triac. It can be used in both half period of the sinusoidal curve.
The switching circuit for the heating element contains an optotriac to isolate the AC power from the MCU power supply. My transformer can produce 9A current with 24V voltage and a C245 type cartridge can consumpt 130-150W during the heating up sequence. I used a typical circuit for the AC part. Fortunately there is no demand for a more complex solution. I chosed a MOC3041 optotriac with internal zero-cross detector. My plan was that I use my individual "zero-cross detector" to generate external interrupts for the MCU at every 10ms. I use the rising and falling edges to find out where the sine wave is at a certain point. Before the zero crossing, the interrupt can switch off the optotriac's LED and at the next halfwave triac will remain in off-state. In that case when thermocouple need to be read but first of all the software must wait some 100us or 1ms after the zero point to be sure the switching transients had eliminated.
To get some experience with an interface IC, I tried the MAX31855 thermocouple IC.
At this point there was an uncertain part of the whole project. Except the manufacturer maybe noone knows the exact type of the thermocouple in the cartridge. On the market there are available thermocouple interface IC-s from Maxim Integrated. I ordered MAX31855 IC N and K type to try out both. First of all I tried the N type. There is an additional thing about this. You can not use grounded thermocouple, so you need to find a solution because the outer sleeve of the C245 cartridge is ESD grounded via 1MOhm resistor (the tip might be ESD safe in a good soldering iron). So I needed to isolate the 5V (and 3,3V) power supply of the MCU from the ground and from the heater circuits.
The result of the experiment: This is not a proper solution to reading temperature values. The main problem is the timing. This interface IC can communicate with the MCU over SPI but the measurements cannot be performed at that point. In the background the IC refresh its registers with the actual (Okay, what is the actual? When? And where? At the top of the sinewave? Yes maybe there, maybe at the middle of the sine, so it is not deterministic...)
It can be seen, the Temperature conversion time has a massive jitter. 70 to 100ms (5 period of the line sine wave(50Hz)). In this range a specific IC can be anywhere, so we can't hold the precise timings.
What is the precison opamp? And what precison we need to perform here? In this case we have N x 10uV voltage on the thermocouple sensor. At 500°C temperature the sensor gives 10-20mV signal. We have 12bit, 3.3V ADC in the STM32. This means 4096 unit in 3.3V range. One unit is 3.3V/4096=0,0008056640625 => 0.8056640625mV =>805.6640625uV. We have 26uV Siebeck-coefficient, so the error would be 805.6640625uV/26uV/°C=31°C. This is why we need to condition the thermocouple's signal. There is 2 important requirements with the opamp
- The noise on the output need to be as small as possible
- The offset voltage and current need to be as small as possible (~0)
- Singe rail capability (we only have 3.3V MCU supply)
- Rail to rail output (output linearity near the positive and negative supply potential)
My choice was the Texas Instruments OPA335.
Because this soldering station designed for a single 24V AC supply the power stage and the 5V MCU supply need to be separated from each other. Only one point can be common on. This is the GND. The triac is driven by an optotriac. Because the zero crossing detector uses a rectified 24V(eff) power supply what is around 32VDC, it need to be separated from the MCU pin which is 5V tolerant but normally 3.3V. The MCU supply is galvanically separated from the rectified and puffered input supply with an isolated Murata NCS3S4805SC DC-DC converter .
To sum it up, here is the whole schematic drawing according to above mentioned points. You can see that I used a precision amplifier instead of a thermocouple interface IC.
Individual PCB was designed in Altium Designer software. The size of the board is 100x55mm. I always design with 3D components, because later I design a housing for my devices, it can be a big help if I have a precise 3D model of my PCBs.
My ptototype PCB's were made by JLCPCB in China. I am not recommend to make PCB at home (toxic acids, vapours that can harmful for you), okay, to deliver 5 PCB with airplane not so environmentally friendly too... I left the choice for everyone. :) I ordered my boards with 6 days shipping. The total cost is around 25$, but it can be less if you can wait 15-20 working days for the delivery.
I ordered all of components from RS Components (some components from other local stores near my home). The component BOM can be found here.
Just to give you a full overview to the PID, I will share my experiences with different methods.
The first fhing that I have tired is to implement a proper discrete PID, to controlling the plant what is the temperature control for the JBC tip. At university I had some course in controlling topic, but I forgot a lot from that times. Nevertheless I had some experience with Matlab Simulink, so my first try was that. After some problem, I searched for a solution on the web.
I found a PID code and the controlling method here.
void PID_Discrete(void){
b0 = (Kp * (1 + N * Ts)) + (Ki * Ts * (1 + N * Ts)) + (Kd * N);
b1 = -((Kp * (2 + N * Ts)) + (Ki * Ts) + (2 * Kd * N));
b2 = Kp + (Kd * N);
a0 = 1 + N * Ts;
a1 = -(2 + N * Ts);
a2 = 1;
A1 = a1 / a0;
A2 = a2 / a0;
B0 = b0 / a0;
B1 = b1 / a0;
B2 = b2 / a0;
//
E2 = E1;
E1 = E0;
E0 = SetPoint - T_tc;
U2 = U1;
U1 = U0;
U0 = -(A1 * U1) - (A2 * U2) + (B0 * E0) + (B1 * E1) + (B2 * E2);
//
if (U0 > 100) {
U0 = 100;
}
if (U0 < 0) {
U0 = 0;
}
OutputDuty = (((int16_t) U0) / 10) * 10;//rounding output duty up or down to tens 0,10,...,90,100
OutputDutyFiltered=(OutputDutyFilterCoeff1*OutputDuty+OutputDutyFilterCoeff2*OutputDutyFiltered)/100;
}
I have implemented the discrete method and there was massive problems with that. As I earlier said we have 11 half period from the sine curve. In the first half period (0th), tip thermocouple's temperature reading need to be performed with an ADC conversion. With 50Hz line sine frequency we have 10ms in each half period. ADC reading is performed in every 11th half period, so the sampling time is 110ms. With this refresh period the PID control loop would be (yes it was) too lazy. Therefore I implemented a continous-like PID control algorithm. See the following chapter.
At least this solution was used in my project. The basic PID equations were programmed in C language. To give some saturation to the control loop's output, the manipulated signal get some limitations (0-100). Because we only have one side manipulation over the temperature (just heating, not cooling) we need to chasing the point where we don't have overshot (not so good when you set 300°C and firstly the tip heating up to 420°C and cooling down 250°C and heating up to 340°C and so on and so on) and the heating up time is short as possible (the original can heat up from room temperature to 300 within 6seconds).
You can find the original solution here.
void PID_Continous(void){
E1 = E0;
E0 = SetPoint - T_tc;
Integral = Integral + (E0 * 0.11);
if(Integral<-100){
Integral=-100;
}
if(Integral>100){
Integral=100;
}
Derivative = (E0 - E1) / 0.11;
U0 = Kp*E0 + Ki*Integral + Kd*Derivative + Bias;
if (U0 > 100) {
U0 = 100;
}
if (U0 < 0) {
U0 = 0;
}
OutputDuty = (((int16_t) U0) / 10) * 10;
OutputDutyFiltered=(OutputDutyFilterCoeff1*OutputDuty+OutputDutyFilterCoeff2*OutputDutyFiltered)/100;
}
For me these coefficients gave the best result. Not particularly large error in temperature (5°C overshoot) and no steady-state error. Quick heating and reaction for the disturbances thanks to the derivative term. Feel free to take some experiments in tuning your control loop to meet your demands.
Coefficient Name | Value |
---|---|
Proportional gain - Kp | 1.7 |
Integral gain - Ki | 0.15 |
Derivative gain - Kd | 0.5 |
I used the free STemWin GUI library to give a simple graphic user interface for this project. As in my other projects also in this was used an inexpensive 240x320 pixel LCD module from ebay. To avoid problems I used my own low level driver for this Arduino typed LCD module.
The system can sense the unconnected soldering iron, if you use this function. If you don't want to use, make permanent connection between GND and SNC input. If you need this feature, find the way that can connect SNC to GND when soldering iron is plugged in. My solution was that I modified the connector of the soldering iron. I soldered a free pin to the GND in the connector. When the solderint iron's connector is not connected to it's socket the SNC input will be high thanks to he pullup. When the iron's connector is plugged in to the socket, the SNC sense input will be GND (thanks to the SNC pin that shorted to the GND in the iron's connector). So this simple way can be used to determine iron is connected or not to the soldering station.
It can sense if the soldering iron is in its holder. You need to make your holder from a conductor type material, I recommend aluminum, brass and copper... You need to connect the SLEEP sense input to the holder, and when you put the iron into the holder, that make contact between the ring at the lower end of the iron and the holder. The SLEEP input will be dragged down to the GND potential and the software will handle SLEEP state.
The software can be found here.
As picture show there are 11 half period, in the first period ADC measurement is performed for the thermocouple of the tip. In the left 10 periods the PID calculates the output power demands and controls the triac to hold the setpoint independently of the load on the tip.
I found that it would be easier if I buy a professional holder with tip cleaner.
There are some additional function on the soldering station.
-Can detects the connected or not connected soldering iron.
-Can detects if the soldering iron is in iron holder, and switch to lower temperature range to extend tip's lifetime. This is the sleep function.
-Can detects if tip will be changed, and switches off the heating power.
-Can detects if soldering tip is removed.
Modifications:
-To get the soldering iron not connected (SNC) functionality you need to make a shortcircuit between PIN6 and PIN1 of the soldering iron's male connector.
-To get the tip change functionality you need to modify the schematic. You need to add an other transistor and some resistors like as SNC and SLEEP. New pin need to be configured as input and handled by the software.