The present disclosure relates generally to internal combustion engines and more particularly to light-duty engine diagnostic systems.
Various electronic ignition timing control systems for light-duty engines that power a wide range of devices, such as lawn equipment, chainsaws, and the like are known in the art. Typically, these ignition systems do not have any battery and these engines are manually started with a pull-rope recoil starter. There is a need to obtain data on the operation of these engines for diagnostic purposes and to program electronic control systems of these engines.
According to one aspect of the disclosure, a spark ignition engine system for communicating data includes a capacitive discharge ignition system using a microcontroller for controlling the spark ignition of a light-duty internal combustion engine; a memory device communicated with the microcontroller, wherein the microcontroller obtains engine data from the light-duty internal combustion engine and stores the engine data or software using the memory device; and a powering connection and a separate data connection that are electrically connected to different pins of the microcontroller, wherein the powering connection supplies power to the microcontroller while engine data or software is communicated via the data connection.
According to another aspect of the disclosure, a spark ignition engine system for communicating data includes a capacitive discharge ignition system using a microcontroller for controlling the ignition of a light-duty internal combustion engine; a memory device communicated with the microcontroller, wherein the microcontroller obtains engine data from the light-duty internal combustion engine and stores the engine data or software using the memory device; a data connection coupled with the microcontroller; a separate powering connection coupled with the microcontroller for powering the microcontroller while engine data or software is communicated via the data connection; and an intermediary computing device that is detachably coupled to the data connection and the powering connection while engine data or software is communicated via the data connection.
According to yet another aspect of the disclosure, a spark ignition engine system for communicating data includes a capacitive discharge ignition system using a microcontroller for controlling the ignition of a light-duty internal combustion engine; a memory device communicated with the microcontroller, wherein the microcontroller obtains engine data from the light-duty internal combustion engine and stores the engine data or software using the memory device; and a kill switch that is removably-carried by a cover of the light-duty internal combustion engine, wherein the kill switch is in communication with a data connection electrically linked to the microcontroller and with a separate powering connection electrically linked to the microcontroller, and when the kill switch is removed and disconnected from the data connection and the powering connection, an intermediary computing device is connected to the data connection for communicating data with the microcontroller and the powering connection for providing power.
The following detailed description of exemplary embodiments of this diagnostic system and test mode will be set forth with reference to the accompanying drawings in which:
The methods and systems described herein generally relate to a light-duty gasoline powered spark plug ignited internal combustion engine that includes microcontroller circuitry, which can record and store engine operating data. The stored data can be communicated to an external digital computer such as a personal computer (PC) through an intermediary computing device. The intermediary computing device may also permit the computer to be used to re-program or re-flash the memory of the microcontroller. The engine preferably has a so-called kill switch mounted on a cowl, cover, or housing of the engine that is accessible from the exterior of the engine housing and may be manually actuated by an operator to stop or terminate operation of the running engine. Desirably, the kill switch can be removed from the engine housing and disconnected from terminals at least some of which can then be connected to the intermediary computing device to supply electrical energy to power up the microcontroller and communicate data from the microcontroller to the external computer or from the computer to the microcontroller for re-programming or re-flashing the memory of the microcontroller. After the data communication is completed, the intermediary computing device may be unplugged or disconnected from the terminals and the kill switch reconnected to them and attached to the housing for continued use in stopping or terminating operation of the running engine.
Typically the light duty engine is a single cylinder two-cycle or four-cycle gasoline powered internal combustion engine. A single piston is slidably received for reciprocation in the cylinder and connected by a tie rod to a crank shaft attached to a fly wheel and typically having a capacitive discharge ignition “CDI” system for supplying a high voltage ignition pulse to a spark plug for igniting an air-fuel mixture in the engine combustion chamber. These engines do not have a separate battery for supplying an electric current to the spark plug and powering the engine electronic ignition control circuitry and micro-processor. Typically these engines are manually cranked for starting with an automatic recoil rope starter.
The term “light-duty combustion engine” broadly includes all types of non-automotive combustion engines, including two- and four-stroke engines typically used to power various devices, such as internal-combustion gasoline-powered hand-held power tools, lawn and garden equipment, lawnmowers, weed trimmers, edgers, chain saws, snowblowers, personal watercraft, boats, snowmobiles, motorcycles, all-terrain-vehicles, etc. The system and method can record data relating to one or more operating characteristics of a light-duty engine. This data can be obtained using firmware stored on a microcontroller that also controls the engine system. That way, if a light-duty engine is returned to the manufacturer (or other facility, such as a repair shop) after it was sold to its end user, technicians can access the data and try to determine how the engine has been used or what, if anything, went wrong. In one implementation, the data can be obtained from the light-duty engine via a kill switch terminal that includes a powering connection and a data connection that are in communication with the microcontroller of the device and communicated to an external computer.
This system and method can aid the manufacturer with diagnosing problem(s) that may exist with respect to the engine. For instance, retailers can sell devices having light-duty engines to consumers and often include a warranty that may be serviced by a manufacturer of the device. When a customer returns a device to the retailer, the underlying reason for the return may not always be apparent to the manufacturer of the device. For instance, the manufacturer may initially inspect the engine of the device and find no defect. And it may be possible that a customer may have wrongly determined that the engine does not operate correctly or simply not been entirely forthcoming about the actual use of the device. Therefore, when a technician later operates the returned device it may appear to operate normally or in a manner inconsistent with the description offered by the customer/operator.
In another example, light-duty engines may be used with devices in commercial settings and fail at the end of their service life. Determining the failure point of the light-duty engines used thusly can be valuable to determine service life of light-duty engines and/or yield data that can be used to improve the design and service life of such engines in the future. A thorough unit-by-unit investigation of possible engine failures may be time consuming and unreasonable given the volume of devices that are manufactured. The engine data can reflect the performance of the engine and/or device when it was used in its operating environment. It can then be accessed by a manufacturer or repair facility.
As will be explained in greater detail, light-duty engines can use a capacitive discharge ignition (CDI) system 10—an example of which is shown in FIG. 1—that includes one of a number of control circuits, including the exemplary embodiment described in relation to
Stator assembly 14 may be separated from the rotating flywheel 12 by a measured air gap (e.g. the air gap may be 0.3 mm), and may include a lamination stack 24 having first and second legs 26, 28, a charge coil winding 30 and an ignition coil comprising a primary winding 32 and a secondary ignition winding 34. The lamination stack 24 may be a generally U-shaped ferrous armature made from a stack of iron plates, and may be mounted to a housing (not shown) located on the engine. Preferably, the charge winding 30 and primary and secondary ignition windings 32, 34 are all wrapped around a single leg of the lamination stack 24. Such an arrangement may result in a cost savings due to the use of a common ground and a single spool or bobbin for all of the windings. The ignition coil may be a step-up transformer having both the primary and secondary ignition windings 32, 34 wound around the second leg 28 of the lamination stack 24. Primary ignition winding 32 is coupled to the control circuit, as will be explained, and the secondary ignition winding 34 is coupled to a spark plug 42 (shown in
The control circuit is coupled to stator assembly 14 and spark plug 42 and generally controls the energy that is induced, stored and discharged by the CDI system 10. The term “coupled” broadly encompasses all ways in which two or more electrical components, devices, circuits, etc. can be in electrical communication with one another; this includes but is certainly not limited to, a direct electrical connection and a connection via an intermediate component, device, circuit, etc. The control circuit can be provided according to one of a number of embodiments, including the exemplary embodiment shown in
Referring now to
During operation, rotation of flywheel 12 causes the magnetic elements, such as pole shoes 16, 18, to induce voltages in various coils arranged around the lamination stack 24. One of those coils is charge winding 30, which charges ignition discharge capacitor 48 through diode 59. A trigger signal from the microcontroller 46 activates switch 50 so that the ignition discharge capacitor 48 can discharge and thereby create a corresponding ignition pulse in the ignition coil. In one example, the ignition switch 50 can be a thyristor, such as a silicon controller rectifier (SCR). When the ignition switch 50 is turned ‘on’ (in this case, becomes conductive), the switch 50 provides a discharge path for the energy stored on ignition discharge capacitor 48. This rapid discharge of the ignition discharge capacitor 48 causes a surge in current through the primary ignition winding 32 of the ignition coil, which in turn creates a fast-rising electro-magnetic field in the ignition coil. The fast-rising electro-magnetic field induces a high voltage ignition pulse in secondary ignition winding 34. The high-voltage ignition pulse travels to spark plug 42 which, assuming it has the requisite voltage, provides a combustion-initiating spark. Other sparking techniques, including flyback techniques, may be used instead.
The microcontroller 46, as shown in
For instance, the microcontroller 46 may include a reprogrammable EEPROM that uses flash memory. The microcontroller 46 shown in
Kill switch terminal 44 acts as a manual override for shutting down the engine. The kill switch terminal 44 can include a powering connection 53 and a data connection 55 that each electrically communicate with the microcontroller 46 and are accessible for sending/receiving data to/from the microcontroller 46. As used herein, the kill switch terminal 44 may be used to collectively refer to a number of elements that are included within the dashed line shown on
In one implementation, the kill switch terminal 44 can include a kill switch having a first function (to permit the stoppage of engine operation during normal use) and a second function (to permit the acquisition of data from the microcontroller 46). For example, the kill switch can be a momentary switch that is biased in the open position permitting a user to engage the switch and stop engine operation. Here, the kill switch can be electrically coupled to the powering connection 53, the data connection 55, and the ground terminal lead 47. It is also possible that the kill switch includes a plurality of positions, such as “OFF” and “ON.” In this case, each of the plurality of positions can be selected using a rotating member, such as a key. While certain embodiments are described wherein data acquisition is accomplished by way of a kill switch, any other switch Or terminal coupled to the microcontroller 46 may be used. In this way, an existing switch or terminal may become a kill switch or terminal in that the existing component may have a first function during normal use of the engine and a second function to permit data acquisition from the microcontroller 46. Additionally, a switch or terminal communicating with the microcontroller 46 may be provided, and such a switch or terminal may permit data acquisition to and/or from the controller as its only purpose. That is, the switch or terminal might not have any other use with regard to normal operation or shutting down of the engine.
Each of the first function of engine use and the second function of engine use can use a different electrical and/or physical configuration of kill switch terminal 44. For example, the kill switch terminal 44 can include the powering connection 53, the data connection 55, and the ground terminal lead 47. The powering connection 53 and the data connection 55 can each be attached to a blade-shaped terminal. This can be appreciated from
In some implementations, the circuit 40 can be imprinted on a printed circuit board (PCB) (not shown). And the powering connection blade 53a and the data connection blade 55a can be initially formed using a solid and/or unitary one-piece structure such that blades 53a and 55a are connected to each other electrically and physically. Both the powering connection blade 53a and the data connection blade 55a can be electrically and/or physically attached (via, solder, etc.) as a unitary structure (e.g., a single piece) to the powering connection 53 and the data connection 55 of the circuit 40 implemented on the PCB via connection points 53b and 55b. After the unitary powering connection blade 53a and the data, connection blade 55a have been attached (electrically and physically) to the PCB, the blades 53a and 55a can be physically/electrically separated by removing a frangible portion 57 that can link the blades 53a and 55a during assembly to the PCB. The powering connection blade 53a and the data connection blade 55a can each form a separate “male” terminal. Similarly, the ground terminal lead 47 can also be implemented as a “male” terminal at the kill switch terminal 44. In this configuration, the kill switch terminal 44 can also include the kill switch that uses three “female” receptacles for receiving the powering connection blade 53a, the data connection blade 55a, and the ground terminal lead 47.
Preferably, after the frangible portion 57 has been removed from the terminal 44 the outer perimeter or footprint of its two separate connector legs 53a, 55a collectively have an outer perimeter, width, and thickness which is substantially the same as a conventional spade terminal currently used only as a single engine connection to a conventional kill switch of a light duty engine. This permits utilization of the same conventional kill switch and at the same location as the conventional stop spade connecter terminal for the normal stopping of the operating engine function and when this kill switch is removed also permits the microprocessor powering and data transfer function to be performed through the intermediate device or interface to an external digital computer. This also facilitates the assembly of the terminal 44 to the PCB and routing its electrically conductive traces to both legs 53a, 55a. This also facilitates encapsulating the PCB in epoxy or other polymer to protect it and it is both easier and more cost effective to protect both the control module and the terminal 55. This also permits continued use during assembly to the PCB of the locating hole within the perimeter of the terminal.
In the first function (to permit the stoppage of engine operation during normal use), the female receptacles of the kill switch can receive the powering connection blade 53a, the data connection blade 55a, and the ground terminal lead 47 such that the switch is coupled to the powering connection blade 53a, the data connection blade 55a, and the ground terminal lead 47. While the kill switch is coupled to the powering connection blade 53a, the data connection blade 55a, and the ground terminal lead 47, the kill switch electrically connects to the powering connection 53, the data connection 55, and pin 3 of the microcontroller 46 via resistor 58 shown in
During the second function (to permit the acquisition of data from the microcontroller 46), the kill switch can be physically separated or disconnected from the kill switch terminal 44 such that the powering connection blade 53a, the data connection blade 55a, and the ground terminal lead 47 are no longer received by or in electrical contact with the multipurpose switch. The powering connection blade 53a, the data connection blade 55a, and the ground terminal lead 47 are then exposed and can then be used for data gathering, which will be discussed below in more detail.
Turning to
The intermediary computing device 300 can also include a power supply conditioning circuit 306, an intermediary microprocessor 308, a current-limited signal driver 310, and input signal filtering 312. When the intermediary computing device 300 is coupled to both the circuit 40 (via the powering connection 53, the data connection 55, and the ground terminal lead 47) and the PC 302, the device 300 can use the power supply conditioning circuit 306 to power the microprocessor 46 (shown in
After the microprocessor 46 has been powered up via the powering connection 53 using the power supply conditioning circuit 306, the intermediary microprocessor 308 of the intermediary computing device 300 can access computer code for directing the microprocessor 46 to send data via the data connection 55. The computer code can be implemented in a variety of computer languages known to those skilled in the art, such as “C++,” and stored in an EEPROM accessible by the intermediary microprocessor 308. To send data to or access data from microprocessor 46, the intermediary microprocessor 308 can transmit a command via the current limited signal driver 310 and the data connection 55 that is readable by the microprocessor 46. After the microprocessor 46 receives the command from the intermediary microprocessor 308, the microprocessor 46 acts on the command and sends stored data to the intermediary computing device 300 via the data connection 55 or prepares to receive additional data from the device 300 via the connection 55. The intermediary computing device 300 can receive data from the processor 46 and pass it through the input signal filtering block 312 to the intermediary microprocessor 308. The intermediary microprocessor 308 can then send the received data to the PC 302 via the port 304. The system can be designed such that when the powering connection 53 and the data connection 55 are electrically connected together, the data connection 55 may be unable to communicate data because more current will be required to power the microprocessor 46 than will be available. This can ensure the separate use of the powering connection 53 and the data connection during data transfer. For instance, the current limited signal driver 310 can restrict current such that when current flows through both the powering connection 53 and the data connection 55 when they are electrically connected together the microcontroller 46 will not receive enough power to carry out data transfer. In one implementation, the current limited signal driver 310 can limit current to values ≦1.0 milliamps (mA). Thus, when the powering connection 53 and/or the data connection 55 are electrically connected together, current amounts used to obtain data cannot be obtained.
Once the PC 302 receives the data, the PC 302 can read the data using a software program suitable for reading such data. Much like the software used by the intermediary microprocessor 308, the software used by the PC 302 to read the data from the microprocessor 46 can be created in a variety of computer languages known to those skilled in the art, such as “C++.” While the microcontroller 46 is powered via powering connection 53, the data connection 55 can bi-directionally communicate data from pin 3 of the microcontroller 46 through intermediary computing device 300 to an outside source, such as the PC 302. This exchange of data can include obtaining stored engine data from the microcontroller 46 or reprogramming or re-flashing the memory of the microcontroller 46.
Turning to
When the switch-removed configuration 404a reveals the powering connection blade 53a, the data connection blade 55a, and the ground terminal 47, the intermediary computing device 300 can be connected to the powering connection blade 53a, the data connection blade 55a, and the ground terminal 47 via a wire 408 that is terminated with a plug 410. The surface of the plug 410 that is fitted to the powering connection blade 53a, the data connection blade 55a, and the ground terminal 47 on or through the switch-removed configuration 404a is shown in more detail at 410a. The plug surface 410a includes individual and separate female receptacles for each of the powering connection blade 53a, the data connection blade 55a, and the ground terminal 47. These elongated female receptacles are shown on surface 410a in a perspective view as a first female receptacle 412 and a second female receptacle 414. A third female receptacle 416 is also shown in a perspective view on the surface 410a as a circular female receptacle for receiving the pin ground terminal 47. Once the plug 410 is mated with the powering connection blade 53a, the data connection blade 55a, and the ground terminal 47 via the switch-removed configuration 404a, data communication can commence between the PC 402 and the microcontroller 46 (shown in
Turning to
At step 515, it is determined whether an engine revolution of the engine crankshaft has been completed. This can be established by detecting the electrical pulses that are generated by pole shoes 16, 18, and/or permanent magnet 17 when they induce a magnetic flux in the nearby stator assembly 14. The microcontroller 46 can then detect the presence of these pulses within a certain time period and determine a beginning of the engine revolution and an end of the engine revolution. If the microcontroller 46 detects the end of the engine revolution, then the method 500 proceeds to step 520. Otherwise, the method 500 repeats step 515.
At step 520, the occurrence of one or more engine revolutions and the time it takes to occur is recorded. This can be done by the microcontroller 46. In one example, this can be carried out by detecting the amount of time that has passed since the last engine revolution. Using the time that has passed between successive engine revolutions can indicate the speed of rotation of the engine crankshaft which can be used to determine the RPM of the engine. In one example, the microcontroller 46 can calculate the amount of time that has passed between successive engine revolutions. The microcontroller 46 can then access a lookup table stored in the memory of the microcontroller 46 that includes a number of categories. Each category can include a time range that is associated with an engine RPM range. When the microcontroller 46 determines that the time that has passed between successive engine revolutions falls within the time or RPM range of a particular category, a value associated with that category is incremented. For instance, if the microcontroller 46 accesses the lookup table and determines that the amount of time that has passed indicates that the engine is operating at 5200 RPM, the microcontroller 46 increments the value of a category associated with the engine running between 5000-6000 RPM. A plurality of categories can be maintained at the microcontroller 46. For instance, categories can be maintained for a large RPM range, such as between 2,000-11,000 RPM, and the categories can be delineated by various increments, such as 500 RPM, 1000 RPM, or both. The microcontroller 46 can maintain/store data representing the cumulative number of engine revolutions occurring, as well as any other engine data, over the life of the engine. This data is one example of engine data. As subsequent engine revolutions are recorded, those engine revolutions are added to previously-recorded engine revolutions and the number and/or rate of RPM over a period of time can be calculated based on this comparison. That is, in one example, RPM can be determined by the number of revolutions the microcontroller 46 detects during a minute of time. As the engine operates, RPM can be recorded during the time the engine operates and can be stored on the microcontroller 46. The method 500 then proceeds to step 525.
At step 525, it is determined if the engine has stopped. In one example, this can involve the microcontroller 46 detecting the activation of the kill switch terminal 44. If it is determined that the engine has stopped via the kill switch 44, the method 500 proceeds to step 530. Otherwise, the method 500 then proceeds to step 535.
At step 530, the number of engine stops is incremented. In one example, this can involve the microcontroller 46 accessing a previously stored number of engine stops that was loaded from the memory of the microcontroller 46 onto the RAM and adding one more to that value. The microcontroller 46 can maintain/store data representing the cumulative number of engine stops occurring over the life of the engine. When the microcontroller 46 detects an engine stop, the recorded number of engine stops can be incremented. The method 500 then proceeds to step 545.
If it has not been determined that the engine stopped at step 525, it is determined if the engine has stalled at step 535. In one example, an engine stall can be determined by the microcontroller 46 when it detects an absence of pulses generated by the pole shoes 16, 18 and/or no magnetic flux in the nearby stator assembly 14 coupled with an absence of kill switch terminal 44 activation. If an engine stall is detected, then the method 500 then proceeds to step 540. Otherwise, the method 500 proceeds to step 515 and continues to record engine data.
At step 540, the number of engine stalls is incremented. In one example, this can involve the microcontroller 46 accessing a previously stored number of engine stalls that was loaded onto the RAM and adding one more to that value. The microcontroller 46 can maintain/store data representing the cumulative number of engine stalls occurring over the life of the engine. When the microcontroller 46 detects an engine stall, the recorded number of engine stalls can be incremented. The method 500 then proceeds to step 545.
At step 545 the previously-stored values of engine data are overwritten with newly recorded data. This can take place when the engine has either stopped or stalled, in one example, the microcontroller 46 accesses the data that has been stored on the RAM while the engine is running and writes it onto its memory, such as flash memory, carried by the microcontroller 46. This can mean that the engine data obtained during steps 520, 530, and/or 540 is added to previously-gathered engine data and recorded for later access. In other words, the engine data gathered in method 500 is cumulative, such that the data obtained during the most recent engine use is added to previous engine operation. The method 500 then ends.
It of course be understood that the foregoing description is of preferred exemplary embodiments of the invention and that the invention is not limited to the specific embodiments shown. Various changes and modifications will become apparent to those skilled in the art and all such variations and modifications are intended to come within the spirit and scope of the appended claims.
This application claims the benefit of U.S. Provisional Application No. 61/790,419 filed Mar. 15, 2013, which is incorporated herein by reference in its entirety.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2014/024103 | 3/12/2014 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
61790419 | Mar 2013 | US |