Rainflow-counting algorithm
The rainflow-counting algorithm (also known as the "rain-flow counting method") is used in the analysis of fatigue data in order to reduce a spectrum of varying stress into a set of simple stress reversals. Its importance is that it allows the application of Miner's rule in order to assess the fatigue life of a structure subject to complex loading. The algorithm was developed by Tatsuo Endo and M. Matsuishi in 1968.[1] Though there are a number of cycle-counting algorithms for such applications, the rainflow method is the most popular as of 2008.
Downing and Socie created one of the more widely referenced and utilized rainflow cycle-counting algorithms in 1982,[2] which was included as one of many cycle-counting algorithms in ASTM E 1049-85.[3] This algorithm is used in Sandia National Laboratories LIFE2 code[4] for the fatigue analysis of wind turbine components.
Igor Rychlik gave a mathematical definition for the rainflow counting method,[5] thus enabling closed-form computations from the statistical properties of the load signal.
For simple periodic loadings, such as Figure 1, rainflow counting is unnecessary. That sequence clearly has 10 cycles of amplitude 10 MPa and a structure's life can be estimated from a simple application of the relevant S-N curve.
Compare this with Figure 2 which cannot be assessed in terms of simply-described stress reversals.
Algorithm
- Reduce the time history to a sequence of (tensile) peaks and (compressive) valleys.
- Imagine that the time history is a template for a rigid sheet (pagoda roof).
- Turn the sheet clockwise 90° (earliest time to the top).
- Each tensile peak is imagined as a source of water that "drips" down the pagoda.
- Count the number of half-cycles by looking for terminations in the flow occurring when either:
- It reaches the end of the time history;
- It merges with a flow that started at an earlier tensile peak; or
- It flows when an opposite tensile peak has greater magnitude.
- Repeat step 5 for compressive valleys.
- Assign a magnitude to each half-cycle equal to the stress difference between its start and termination.
- Pair up half-cycles of identical magnitude (but opposite sense) to count the number of complete cycles. Typically, there are some residual half-cycles.
Example
- The stress history in Figure 2 is reduced to peaks and valleys in Figure 3.
- Half-cycle (A) starts at tensile peak (1) and terminates opposite a greater tensile stress, peak (2); its magnitude is 16 MPa.
- Half-cycle (B) starts at tensile peak (4) and terminates where it is interrupted by a flow from an earlier peak, (3); its magnitude is 17 MPa.
- Half-cycle (C) starts at tensile peak (5) and terminates at the end of the time history.
- Similar half-cycles are calculated for compressive stresses (Figure 4) and the half-cycles are then matched.
Stress (MPa) | Whole cycles | Half cycles |
10 | 2 | 0 |
13 | 0 | 1 |
16 | 0 | 2 |
17 | 0 | 2 |
19 | 1 | 0 |
20 | 0 | 1 |
22 | 0 | 1 |
24 | 0 | 1 |
27 | 0 | 1 |
Block Loading example
There are many cases in which a structure will undergo periodic loading. Assume that a specimen is loaded periodically until failure. The number of blocks endured before failure can be determined easily by using the Palmgren-Miner rule of block loading. The actual load history is shown in Figure 5.
If all of the similar loads are grouped together, it forms a series of block loads as shown Figure 6.
The Palmgren-Miner rule can be expressed as
where,
- B = number of blocks
- Nk = number of cycles of loading condition, k
- Nfk =number of cycles to failure for loading condition, k
In this example, each Nk=1 because there is one instance of each load for every period of loading. To find Nf (number of loads to failure) for each load the Goodman-Basquin relation can be used
where,
- σa = stress amplitude
- σ'f = fatigue strength coefficient (material property)
- σm = mean stress
- σult = ultimate stress (material property)
- b = fatigue strength exponent (material property)
Assumptions
There are two key assumptions made in order to rearrange the loads into blocks. These assumptions may affect the validity of the procedure depending on the situation.
- The loads are independent.
- The order of loading does not matter.
References
- ↑ Matsuishi, M. & Endo, T. (1968) Fatigue of metals subjected to varying stress, Japan Soc. Mech. Engineering.
- ↑ Downing, S.D., Socie, D.F. (1982). Simple rainflow counting algorithms. International Journal of Fatigue, Volume 4, Issue 1, January, 31-40.
- ↑ ASTM E 1049-85. (Reapproved 2005). "Standard practices for cycle counting in fatigue analysis". ASTM International.
- ↑ Schluter, L. (1991). Programmer's Guide for LIFE2's Rainflow Counting Algorithm. Sandia Report SAND90-2260.
- ↑ Rychlik, I. (1987) A New Definition of the Rainflow Cycle Counting Method, Int. J. Fatigue 9:2, 119-121.
External links
- StoFlo freeware rainflow cycle counting Excel template
- Matlab Central rainflow counting method
- WAFO. Wave Analysis for Fatigue and Oceanography (Matlab)
- GAC freeware rainflow cycle counting
- Vibrationdata Rainflow Tutorials & Matlab scripts