In this article, a calculation of contact pressure in a rough contact is discussed. The calculation is done using a Tribology Simulator software, which is available for download here (its free to use). The simulator uses a Boundary Element Method (BEM) with Fast Fourier Transform and Conjugate Gradient method to obtain the contact pressure and the real contact area at a contact of two rough surfaces (it can also be used to calculate subsurface stresses and other kind of tribology related problems). The model is based on the half-space theory approximation. In a recently published Contact Mechanics Challenge results, it was shown that BEM based approach (along with a computationally demanding Green’s Functions approach) is the most accurate way to calculate contact pressure for rough surfaces.
As of today, the most efficient way in terms of the accuracy and efficiency, BEM based approach is the most suitable way of characterizing contact situation between rough surfaces (this also includes subsurface stress calculation, stiffness and pre-sliding analysis). This is due to the fact that other methods, such as Finite Element Methods, or Molecular Dynamic models are much more computationally intense and solution of many practical problems is not feasible. BEM solution is based on the solution of the classical equations of the theory of elasticity for a semi-infinite half-space with homogeneous mechanical properties (although BEM approach was also extended for layered surfaces, and non-homogeneous surfaces as well). For such a half-space, the elastic deflection is given in a form of an integral (as discussed in more detailed manner here):
Here is the elastic deflection, is the reduced elastic modulus, are the Poisson’s ratio and Young’s modulus of the bodies, is the contact pressure. This equation is used in most of tribological problems involving rough surfaces, including EHL problems, but also in contact analysis, friction and wear simulation.
The system of equations to be solved in this case looks as follows:
Here, is the combined surface roughness of the surfaces, is the rigid body approach and are the contact area and applied normal load correspondingly. Once the system is solved, one gets the contact pressure and the real contact area. This system of equations can be extended to consider the plastic behavior of the materials as well as to have friction on the surface and coatings.
Tribology Simulator is a stand-alone software for tribological analysis. First, it should be downloaded and launched (you will also need to download an MCR installer from MATLAB site, see the readme file). A following window will show up:
On the left side, the global settings steps of the problem are shown. You start with the selection of the Simulation Type, which in the current article is the dry contact simulation. Next, the macroscopic geometry is set. This can be a cylindrical, spherical, elliptical shape or just a flat. It is instructive to use a sphere here as an example. The radius of the sphere is chosen in the table. It should be noted that the settings for the simulation can be loaded from the file (previously saved). For simplicity, it is good to do so: on the context menu, click File, Load parameters. In the dialogue window, go to the Examples\Contact Pressure Calculation and select ‘Parameters.mat’ file. All the simulation settings will be imported.
At the next step, it is necessary to define the microscopic geometry, which is known in tribology field as roughness (there is a possibility to consider a smooth contact analysis as well, then the solution will be identical to the Hertz contact solution). In this post, we will consider an artificially generated surface (you can do it by choosing Tools/Surface Generator), which is located at the same place as the parameters file imported on the previous step. Although it is not necessary, it is instructive to take a look how does the surface roughness look. For that, click the Import Roughness button and choose the Examples\Contact Pressure\Surface Roughness.csv file (it is also possible to import surfaces in other formats) and if everything is alright, you will see the profile on the graphic panel. Some parameters of the surface will also be shown to the left from the plot. It should be noted, that the original surface is interpolated to the numerical grid which is defined later on. This particular file is just a matrix of of heights in meters. It is important in this case to manually define the resolution of the roughness profile in the corresponding table.
Now go further to the Contact Model. There are several available, but for now we use Half-Space Based model (see the Help\Manual for the description of other models). It is also possible to calculate the subsurface stress (check this option if you would like to do that as well, but be careful it gets more time consuming).
With the next step, you can specify the properties of the bodies in contact. In the corresponding table you specify Elastic modulus in Pa, Poisson’s ratio (dimensionless) and the hardnesses of the materials (in Pa). If you want to perform purely elastic calculations, set the hardness values to a very high value. The half-space approximation theory was also used to get the solution for the coated surfaces (layered). In Tribology Simulator, there is also an option to consider a single layer on top of each of the surfaces (see more details in the manual).
In the next step, it is necessary to choose the friction model. The friction of the surface impacts the contact pressure, since the shear forces introduces displacements and this is taken into account in the model. The simplest model is the Coulomb model and it is assumed then that the coefficient of friction (COF) is constant. For the current simulation, 0 COF can be chosen simulating traction free surface.
Now go to contact conditions (we skip the wear, thermal and tribochemical models in this article) to choose the contact (normal) load. In this table, for dry contact pressure analysis only the load has to be set (you can also specify several loads using a whitespace as a separator). Here you also need to specify the boundary conditions. In the current simulation, no periodic boundary condition is used (so 0 pressure at the outside). In the table at the bottom of the panel, the hertz parameters are calculated. These parameters can be used to set the dimensions of the computational grid. For example, if the Hertz contact radius is 200 , then the computational domain should be at least twice as this value.
The last step in this simulation set up is the setting of the numerical grid. That is on the Contact Grid panel. In the table, in the first row you need to enter the length of the numerical grid in x and y directions (also in z direction, if you calculate subsurface stresses). In the second row you need to specify the number of grid points. The last row will show the resolution of the grid (it will be calculated as the length divided by the corresponding number of grid points).
Now you can proudly press the big bang Run button. The simulator will ask you to choose the roughness file. You will see a small progress text on the left bottom part of the simulator window. If you consider more than one load, it will show you the progress of the simulation. In the Windows Command Shell window, you will be updated as well. You can now choose the Results row and once the simulation is over, the new window will appear and the last calculated results will be loaded.
On the Results panel, it is possible to plot the calculated variables. In our case, we are interested in the contact pressure. So we choose Contact Pressure in the listbox and click plot. A pressure profile like this will be shown:
This is how the pressure profile at the contact interface look like (the scale is in Pa unit). It is possible to export this data by clicking Export button (you can export it to matlab or csv file). It is obvious here, that the Hertz radius approximately encircles the contact area here as well (the Hertzian radius is found in the table at the Contact Conditions panel).
I hope this helps!
Administration of the project