Method for real-time communication between a number of network subscribers in a communication system using ethernet physics, and a corresponding communication system using ethernet physics

Information

  • Patent Application
  • 20020037007
  • Publication Number
    20020037007
  • Date Filed
    July 30, 2001
    23 years ago
  • Date Published
    March 28, 2002
    22 years ago
Abstract
For real-time communication between a number of network subscribers in a communication system using Ethernet physics, the slave units are synchronized to the master unit in that each slave unit is clocked via a respective timer with a predetermined overall cycle time, which timer is set cyclically by the reception of respective slave-specific synchronization information which is determined by the master unit. In this case, each timer in a slave unit automatically starts a new cycle once the predetermined overall cycle time has elapsed, even in the absence of the respective synchronization information. Access control for the transmission mode and reception mode between the network subscribers is provided using a timeslot access method.
Description


BACKGROUND OF THE INVENTION

[0001] As widely differing technical systems are increasingly networked, there is a growing requirement for standardized structures in industry. In this context, it is also desirable to be able to couple any desired appliances locally. In order to provide open systems for networking, it is necessary to provide simple and cost-effective communication mechanisms which enable industrial appliances to have a networking capability. In particular, this requirement also exists in the context of the coupling of drive components, such as drive controllers, power sections and transmitters, for numerically controlled machine tools and robots, in which a number of interpolating axes must be operated synchronously.


[0002] In present-day high-performance drive systems, the interfaces to transmitters and power sections are in the form of analog signal interfaces. This, however, involves considerable restrictions relating to the spatial distribution capability, since the susceptibility to interference from EMC effects (EMC stands for electromagnetic compatibility) increases with the cable length. If the performance requirements are low, proprietary company serial digital transmission systems are generally used. Where the performance requirements are high, the communication between the drive controller and the movement controller is provided by proprietary-company serial data transmission systems.


[0003] Recently, with regard to the requirement to provide industrial appliances with a networking capability the ETHERNET (data transmission rate 10 Mbps), in particular the FAST ETHERNET (data transmission rate 100 Mbps—IEEE Standard 802.3-1998) data transmission technology which is known from office technology, has been becoming increasingly important. This is due to the fact that this development represents an undefined Standard with regard to compatibility and, furthermore, is available at low cost, since appropriate interface hardware is being produced in large quantities, owing to the widespread use in the field of personal computers. Furthermore, ETHERNET networks are already widely used in many organizations, so that a widely extended infrastructure can already be made use of. These arguments all favor the use of the ETHERNET in the field of automation technology as well. ETHERNET is generally used in the field of Local Area Networks LAN, with the most widely used transmission protocol being TCP/IP (Transmission Control Protocol/Internet Protocol).


[0004] Accordingly, the IEEE Standard 802.3, CSMA/CD (Carrier Sense Multiple Access/Collision Detect) is generally used as the access method. In this method, all the network subscribers have equal priority, and any network subscriber is allowed to send a message on the network, generally a bus system at any time. However, a problem occurs in this case when two or more subscribers are sending a message at the same time. In this situation, a collision is identified, and each subscriber involved is then assigned a waiting time, which is defined randomly, before another attempt to send the message is made. The term statistical access method is therefore used.


[0005] The requirements for the performance of communication systems for automation technology are particularly stringent, for example when coupling drive components. When interchanging data between transmitters, power sections and a drive controller, the data transmission time, which is included in the control loop as a dead time, is a particularly important parameter. The shorter this dead time, the better the dynamic response which can be achieved by the control system.


[0006] The connection between movement controllers and drive controllers is also sensitive to dead times, since a control loop is also closed via this connection. There is thus a problem in particular in the data transmission time for serial communication systems, which can be solved only by an appropriately fast system with a real-time capability, that is to say a deterministic system. However, the fact that communication using ETHERNET networks does not ensure a determined time response runs counter to their use for automation technology. The ETHERNET Standard therefore does not offer the technical preconditions for real-time communications.


[0007] IEEE Standard 802.3 defines a message frame which is not suitable for this purpose. Since, however, the components for physical ETHERNET signal transmission are independent of the Standard protocol form, the developer has freedom to choose the protocol form in which the data are to be transmitted. Only Layer 1 (the physical layer) is adopted from IEEE Standard 802.3.



SUMMARY OF THE INVENTION

[0008] The object of the present invention is to provide a transport protocol which allows real-time communication while including the widely used Ethernet physics. According to the present invention, this object is achieved by a method for real-time communication between a number of network subscribers in a communication system using Ethernet physics, wherein:


[0009] a master unit and one or more slave units communicate with one another by means of messages which are transmitted via the network;


[0010] the messages are interchanged cyclically with equidistant sampling times, in that each slave unit is synchronized to the master unit by means of a common timebase; and


[0011] access control for the transmission mode and reception mode is carried out between the network subscribers using a timeslot access method.


[0012] Since the aforementioned applications require both high-precision compliance with the real-time condition and a high level of security and reliability in the transmission, the standardized transmission layer 2 (message frame and access method) of the (Fast) Ethernet, which does not satisfy these requirements, is completely redefined by a new message frame and a new access control method, and the Ethernet physics are thus used as the basis for real-time communication between, for example, drive components. Both the communication between the control unit and the transmitters and power sections, and the connection to a movement controller, can be provided in this way.


[0013] With regard to synchronization between the master and slave units, it has been found to be advantageous for the slave units to be synchronized to the master unit by each slave unit being clocked via a respective timer with a predetermined overall cycle time, which is set cyclically by the reception of a respective slave-specific synchronization information item, which is determined by the master unit. A master-slave communication architecture is thus used. In order to allow cyclic data interchange with identical sampling times to be provided, a common time base is produced for the master and all the slaves. The slaves are synchronized to the master by means of specifically defined messages, defined in time, from the master to the slaves, and individually configured timers in the slaves. User data messages and specific synchronization messages, which contain the respective synchronization information, can be transmitted in this way. Alternatively, the synchronization information can also be integrated in a specifically defined user data message. The stability of the communication system can be further enhanced if each timer in a slave unit automatically starts a new cycle once the predetermined overall cycle time has elapsed, even in the absence of the respective synchronization information.


[0014] A timeslot access method, which is initialized by the master in the network and allows optimum dead-time data transmission, is used for cyclic data transmission for the transmission and reception modes. Accordingly, messages can be monitored precisely for premature or delayed transmission, or for transmission subject to interference. For this purpose, only the master unit, has transmission authorization on the network for initialization, and reports to each slave unit which has only response authorization, via an appropriate slave-specific message. In addition to the overall cycle time, the time slots within the overall cycle time determine when the respective slave unit will receive messages from the master unit and the times at which it should send its messages. It has been found to be advantageous if each slave unit is told the respective synchronization time in the initialization phase.


[0015] Simultaneous and equidistant sampling for a control system can be achieved by storing instantaneous values in each slave unit at a common time, in particular at the start of a cycle.


[0016] In a preferred embodiment of the method according to the present invention, monitoring information is provided in each message which is transmitted by the master unit to a slave unit, by means of which security or safety functions which are provided in the slave unit can be activated directly via a second initiation channel.


[0017] The user data can be transported in a message frame which, in addition to slave addressing and message length information, provides protection of the data integrity by means, for example, of a CRC checksum and further security and safety related data areas. The data in the message frame can be evaluated not only by an application processor, but also by a communication module, which allows a second initiation channel. For this purpose, each slave unit sends a life signal with each message to the master unit. The absence of this signal indicates that the slave system has crashed, and the master unit stops this slave unit in a controlled manner by means of the second initiation channel (without the assistance of the slave unit). Furthermore, in the user data area of its message to the slave unit, the master unit can initiate a function in the slave unit, and can initiate this simultaneously by means of a signal in the second initiation channel. Two-channel initiation is thus achieved, which is an essential requirement for certain security or safety applications. The master unit can also send a master life signal in each of its messages to the slave units. In the absence of this signal, all the slaves react by stopping their own functions in a controlled manner.


[0018] Although the transmission technology based on the Ethernet Standard allows only point-to-point connections, it is also possible to form networks by using network nodes (which are referred to as HUBs) in (fast) Ethernet networks by a number of network subscribers, or each network subscriber, having one circuit part in order to form network nodes. The circuit part is used for passing on the messages in the direction of another master unit or further slave units, wherein communication between network subscribers via network nodes likewise takes place as claimed in one of the procedures described above.


[0019] Furthermore, separate transmitting and receiving lines between two network subscribers can be used simultaneously. This is done, for example, based on the rule that all the slave units transmit only in the direction of the master unit, and receive only messages directed from the master unit. This means that a message from the master in the direction of a slave and a message from a slave in the direction of a master can be transmitted simultaneously. This allows for full-duplex operation.


[0020] Real-time communication can be achieved on the basis of a communication system using Ethernet physics by means of the procedure described above. In this case, hierarchical networks can also be produced by means of point-to-point connections, connected via network nodes, using Ethernet physics for carrying out real-time communication in relatively large network topologies. This is also suitable for networking or coupling a distributed drive system, in that a first communication system comprises a numerical movement controller as the master unit and at least one control unit as the slave unit. Each control unit is used as the master unit for a further communication system, which has at least one power section for driving a motor and an associated transmission system as slave units.


[0021] Security and safety applications can also be provided since the communication between the drive components, such as a control unit, transmitter, power sections and movement controllers, is accomplished by means of an existing high-performance transmission system from the office communication field, by means of a completely new protocol, master-slave synchronization and a timeslot access method, for a real-time capability.


[0022] The use of the (fast) Ethernet transmission technology including the method according to the present invention thus results, inter alia, in the following advantages:


[0023] low-cost line drivers, since large quantities of these are used in office communication technology—a proven technology which is also used in industry;


[0024] the line drivers allow any desired protocol and full-duplex operation;


[0025] better cable material can be used than for multi-core analogue signal cables;


[0026] the distances between the components can be greater than when using analog signal cables;


[0027] shorter dead times can be achieved by means of high transmission performance levels of up to 100 Mbps with fast Ethernet; and


[0028] even complex networks can thus also be constructed.







DRAWINGS

[0029] Further advantages and details of the present invention are described below in conjunction with the figures, in which:


[0030]
FIG. 1 shows an outline illustration of a movement controller and a drive appliance having two axes, based on the communication system of the invention;


[0031]
FIG. 2 shows a timing diagram of the timer synchronization in a slave;


[0032]
FIG. 3 shows an illustration of the timeslot access method;


[0033]
FIG. 4 shows an illustration of one possible message frame;


[0034]
FIG. 5 shows an illustration of one possible function code within a message frame; and


[0035]
FIG. 6 shows an outline illustration for a second initiation channel for security and safety applications.







DETAILED DESCRIPTION OF THE INVENTION

[0036]
FIG. 1 shows an example of a movement controller NC and of a drive appliance with two axes, which are coupled by means of a first communication system KOMSYS1 based on Ethernet physics. The drive controller R is connected to its power sections A1, A2 and transmitters S1, S2 by means of its own independent communication system KOMSYS2. Each power section A1 and A2 is used to drive the respective motor M1, M2, to which respective sensors S1, S2 in the form of transmitter systems are in turn connected, in order to detect the current, rotation speed and position and orientation information required for position and orientation control.


[0037] With regard to the first communication system KOMSYS1, the movement controller NC represents the master unit, which communicates with a number of controllers R (FIG. 1 shows only one control group, for the sake of clarity) as slave units. In the second communication system KOMSYS2, the controller R forms the master unit, while the actuators A1, A2 and sensors S1, S2 represent the slave units.


[0038] The network subscribers are connected via fast Ethernet line drivers PHY within each network subscriber. By way of example, the line driver modules PHY of the fast Ethernet are used for physical data transmission, on the basis of a copper cable having at least four cores, or a two-conductor optical waveguide.


[0039] In order to network different communication systems, all the network subscribers, or some of them (in the present case, the movement controller NC and the actuators A1, A2) have circuit parts HUB which are connected downstream from the line driver modules PHY and are used to pass on the messages in the direction of the master or further slaves. It is thus possible to form a hierarchical network, as shown in FIG. 1.


[0040] The messages are passed via the line drivers PHY and any network nodes HUB to the respective protocol modules Kom, which process the message protocol and in which the timeslot access method according to the invention is used. To this end, the principle of synchronization between a master and a slave will be described first of all as is shown in FIG. 2, in the form of a timing diagram with counter values n plotted against time t. Each slave has a timer which is set to a specific value (Nsync) by the reception of a specifically defined slave-specific message (for example a synchronization message which may also transport user data) from the master relating to the synchronization time (Tsync). This value is calculated in advance by the master and is reported together with the overall cycle time (Tcycl) to the slave in an initialization phase. This method allows any possible brief failure of this slave-specific synchronization message to be bridged, since the counter starts a new cycle once the overall cycle time (Tcycl) has elapsed, even without any need to be corrected in the meantime by means of the synchronization message.


[0041] This is seen in FIG. 2, where the profile of a clock signal n with the overall cycle time (Tcycl) is plotted against time t. If the synchronization signal for the slave now fails for a number of cycles, then the timer continues to run autonomously. In this case, discrepancies can occur between the overall cycle clock (Tcycl) and the timer-internal clock, for example due to crystal drift in the counter. Such a clock error is shown in the form of a dotted line. Any error Δ which is present at the synchronization time (Tsync) can be corrected when a synchronization signal is once again available, and this resets the timer.


[0042] The crystal drift between a master and slave (for example ±100 ppm, crystal characteristic) together with the cycle time (Tcycl) of the cyclic data traffic governs the accuracy limits of the timeslots for access control. In this case:


[0043] cycle time×crystal drift>maximum accuracy of the timeslot (example: 1 ms×±200 ppm=±0.2 μs>maximum accuracy of the timeslot).


[0044] Each communication network KOMSYS1, KOMSYS2 of network subscribers consists of one, and only one, master unit and one or more slave units and, according to the invention, is operated for cyclic data interchange using a timeslot access method, in order to achieve optimum dead-time data transmission.


[0045] In an initialization phase, in which only the master may transmit and only the slaves may respond, each slave receives the information on the times at which it will receive messages from the master and on the times at which it can send its message or its messages. The precise definition of the times at which the messages must be sent or received allows the communication to be controlled both at the master end and at the slave end. FIG. 3 shows the sequence of such a timeslot access method according to the present invention.


[0046] Specifically, FIG. 3 shows the access of a master unit MS to two slave units SL1 and SL2 within one overall cycle (Cycl) or (Tcycl). Once a first time Tsend1 has elapsed and after the start of the cycle, the master MS sends a transmitted message Ssl1 to the slave SL1. Owing to the delay times on the communication path, this message arrives at the slave unit SL1 as a received message Rsl1 with a certain time delay dtDel(sl1).


[0047] The interval between the end of the received message and the starting point of the respective overall cycle (Cycl) represents the reception time Trec(sl1) for the slave SL1, which corresponds to the specific synchronization signal Tsync1 for the slave SL1. At this time, the slave SL1 always receives its synchronization signal and its data. This time represents the clock time for the slave unit SL1, and its timer is set to a value corresponding to the time Tsync1. The slave SL1 is thus assigned the timeslot associated with this for reception of messages. The timer is, for example, decremented, with the set value being designed such that the counter zero crossing is coincident with the end of the overall cycle. The slave SL1 now sends its response message Sms1 to the master, to be precise exactly after a transmission time Tsend(sl1) for the slave SL1, measured from the start time of the respective overall cycle. This transmission time Tsend(sl1) is allocated in a fixed manner to the slave SL1, and represents its timeslot for sending messages. This message once again arrives with the delay dtDEL(Sl1) which is governed by the delay time in the communication path, as the received message Rms1 at the master unit MS. The time interval from the start time of the respective overall cycle (Cycl) and the end of the received message Rms1 represents the reception time Trec1 for the response from the slave SL1 from the point of view of the master MS.


[0048] The communication between the master MS and the second slave unit SL2 takes place on the basis of the same fundamental procedure. Once a further time Tsend2 has elapsed after the cycle start, the master MS sends a further transmitted message Ssl2 to the slave SL2. Owing to the delay times in the network, this message once again arrives as the received message Rsl2 at the slave unit SL2 with a certain time delay dtDel(sl2).


[0049] The interval between the end of the received message and the start time of the respective overall cycle (Cycl) represents the reception time Trec(sl2) for the slave SL2. This corresponds to the specific synchronization signal Tsync2 for the slave SL2. The slave SL2 always receives its synchronization signal and its data at this time. This time thus represents the clock time for the slave unit SL2 in a corresponding manner, and its timer is set to a value corresponding to the time Tsync2.


[0050] The slave SL2 is thus assigned the timeslot associated with this for receiving messages. The timer is, for example, likewise decremented, with the set value being designed such that the counter zero crossing is coincident with the end of the overall cycle. The slave SL2 sends its response message Sms2 to the master MS, to be precise exactly after a transmission time Tsend(sl2) for the slave SL2, which is measured from the start time of the respective overall cycle. This transmission time Tsend(sl2) is allocated in a fixed manner to the slave SL2 and represents the timeslot for sending messages. The slave unit SL2 can therefore start to send a message Sms2 to the master MS only before complete reception of the message Rsl2, since the corresponding time slot for sending after Tsend2 is already known from a previous period of the overall cycle (Cycl), and the slave unit SL2 is thus already in the steady synchronization state.


[0051] This message also arrives with the delay dtDEL(sl2), which is governed by the delay time on the communication path, as the received message Rms2 at the master unit MS. The time interval from the start time of the respective overall cycle (Cycl) and the end of the received message Rms2 represents the reception time Trec2 for the response from the slave SL2 from the point of view of the master MS.


[0052] The procedure for the other slave units likewise correspond with each slave unit being allocated its own exclusive timeslot. Hence, it is possible to immediately identify not only interference, but also delayed or premature transmission of a message. A specific message to a slave is used for synchronization in addition to data transmission.


[0053] Apart from timeslot control, the synchronization also means that the actual values can be stored in all the slaves at a specific common time, in this case the start of the cycle (Cycl), in order to achieve simultaneous, equidistant sampling for the controller R. To this end, the respective actual value from each slave unit, in particular from the sensors and transmitter systems S1 and S2, is stored when the corresponding timer reaches its zero crossing, and is then transmitted to the higher-level master unit NC or R. In the case of the drive system with two coupled axes shown in FIG. 1, the slave units S1, S2 supply corresponding rotation speed, position and orientation actual values.


[0054]
FIG. 4 shows one possible message frame for a message T to be interchanged via the network. The message starts with a message preamble PR, the length of which is, for example, 64 bits. This is followed by a function code sequence FCS of 16 bits, which is explained in the following text with reference to FIG. 5. This is followed by 8 bits with the address SLA of the slave unit. In this case, the number of bits required depends on the number of slave units to be addressed. If there are 8 bits, the number of slaves which can be addressed is 255 (the value ZERO is normally reserved for a broadcast function). This is followed by the length LE of the subsequent user data DU. The message length is thus variable. The message frame ends with a checksum CRC with a length, for example, of 32 bits (CRC stands for cyclic redundancy check, a known method for error monitoring).


[0055]
FIG. 5 shows one possible detailed view of the section comprising the function code sequence FCS. The most significant bit contains a supervisor bit SV. This represents a sign of life such that, for example if the control software crashes, it is no longer set in the master. This allows, for example, a change to a safe state to be initiated in the slave.


[0056] The bits 14 to 10 are reserved for any desired tasks. They are followed by three control bits CTRL0 to CTRL2, an area of three to six bits for storing the message type TY and a further bit LI which signals whether any length information is present or whether a fixed, standardized message length can be assumed. The bit M/S signals whether this is a message which is being transported from a master to a slave or vice versa, and thus indicates the transport direction. The last bit SYNC indicates whether this is a synchronization message or a user message. It is also feasible for the SYNC bit to be used to signal that the message contains additional synchronization data as well as user data.


[0057] The control bits CTRL0 to CTRL2 are used, for example, to provide specific security or safety functions, such as those which are required, in particular, in the field of industry automation. One possible implementation of a security or safety function with the aid of the control bits CTRL0 to CTRL2 is shown in FIG. 6 which shows a block diagram with the internal construction of a slave unit, for example of the power section A1, from the drive controller shown in FIG. 1.


[0058] If the module Kom, which receives the message via the line driver PHY and implements the communication protocol, is independent of a microprocessor μP in the slave application (the actual power section L), specific application events can be initiated in the slave A1 by means of the control bits CTRL0 to CTRL2 without requiring the microprocessor μP and the corresponding software in the slave A1. This corresponds to a second initiation channel K2 as is required for certain security and safety applications (for example emergency stop etc.).


[0059] The above method steps according to the invention allow a communication network with a deterministic time response, and hence the capability for real-time communication, to be achieved, in particular for industry automation as well, on the basis of Ethernet physics.


Claims
  • 1. A method for real-time communication between a plurality of network subscribers in a communication system using Ethernet physics, comprising having a master unit and at least one slave unit communicate with one another by means of messages which are transmitted via the communication system; interchanging the messages cyclically with equidistant sampling times so that each slave unit is synchronized to the master unit by means of a common timebase; and using a timeslot access method as access control for transmission and reception communications between the network subscribers.
  • 2. The method according to claim 1, further comprising synchronizing the slave units to the master unit so that each slave unit is clocked via a respective timer with a predetermined overall cycle time, and wherein the respective timer is set cyclically by the reception of a respective slave-specific synchronization information item which is determined by the master unit.
  • 3. The method according to claim 2, wherein user data messages and specific synchronization messages which contain the respective synchronization information items are transmitted.
  • 4. The method according to claim 2, wherein the synchronization information items are integrated in appropriately identified user data messages.
  • 5. The method according to claim 2, wherein the timer in a slave unit automatically starts a new cycle once a predetermined overall cycle time has elapsed, even in the absence of synchronization information.
  • 6. The method according to claims 2 and 5, wherein only the master unit has transmission authorization in the communication system for initialization and reports to each slave unit, and each slave unit has only response authorization, via an appropriate slave-specific message, wherein the overall cycle time has time slots in which the slave unit will receive messages from the master unit and timeslots in which the slave unit should send messages.
  • 7. The method according to claim 6, wherein the slave unit is given a respective synchronization time in an initialization phase.
  • 8. The method according to claim 2, wherein instantaneous values are stored in a slave unit at a common time.
  • 9. The method according to claim 1, wherein with each message a slave unit sends a signal to the master unit, and the master unit stops that slave unit in a controlled manner in the absence of said signal.
  • 10. The method according to claim 1, wherein monitoring information is provided in each message which is transmitted by the master unit to a slave unit, by means of which security or safety functions which are provided in the slave unit can be activated directly via a second initiation channel.
  • 11. The method according to claim 1, wherein the master unit sends a master life signal in each of its messages to each slave unit and, in the absence of this signal, each slave unit automatically reacts by stopping its own functions in a controlled manner.
  • 12. The method in claim 1, wherein separate transmitting and receiving lines between two network subscribers are used simultaneously, so that all the slave units transmit only in the direction of the master unit and receive only messages from the direction of the master unit.
  • 13. A method for real-time communication between network subscribers in a plurality of communication systems using Ethernet physics, wherein, within each communication system network subscriber communicates with one another in accordance with the method of claim 1, and further wherein a number of network subscribers have one circuit part in order to form network nodes, said circuit part being used for passing messages in the direction of another master unit or slave unit, and wherein communication between network subscribers via network nodes is also in accordance with the method of claim 1.
  • 14. A communication system using Ethernet physics for carrying out real-time communication in accordance with the method of claim 1.
  • 15. A hierarchical network having point-to-point connections, which are connected via network nodes, using Ethernet physics for carrying out real-time communication in accordance with the method of claim 1.
  • 16. A distributed drive system having a hierarchical network according to claim 15, wherein a first communication system comprises a numerical movement controller as the master unit and at least one control unit as the slave unit, with each control unit being used as the master unit for a further communication system, which has at least one power section for driving a motor, and an associated transmission system (S1, S2) as slave units.
Priority Claims (1)
Number Date Country Kind
100 479 25.1 Sep 2000 DE