Title | Difference in calculations for Stata versions and processors | |
Author | Theresa Boswell, StataCorp |
Users may encounter slightly different results among different versions or flavors of Stata. These slightly different results may occur when using an estimation command that calls the ml command or when different numbers of processors are used in Stata/MP when using the ml command directly.
These differences are very small and can be ignored because, statistically, the results do not differ. The possible reasons for the slight difference are explained below.
Slight differences in results can arise on the same computer between different versions of an application, even if you run the same command in different versions. Depending on factors such as the operating system version, the processor in the computer, and the compiler used to produce the application, numerical calculations may use different mathematical libraries or may begin an algorithm at slightly different initial values. This may result in very small differences in results from the ml command.
When more than one processor is used in Stata/MP, the computations for the likelihood are split into pieces (one piece for each processor) and then are added at the end of the calculation on each iteration. Because of round-off error, addition is not associative in computer science as it is in mathematics. This may cause a slight difference in results. For example, a1+a2+a3+a4 can produce different results from (a1+a2)+(a3+a4) in numerical computation. When changing the number of processors used in Stata, the order in which the results from each processor are combined in calculations may not be the same depending on which processor completes its calculations first.
To summarize, you should treat SE, MP with one processor, MP with two processors, etc., as different machines—even if they are on the same physical machine—when you want to reproduce results exactly.
When trying to reproduce results, you should use the same operating system, application version, and processor type. This is particularly true when using any estimation command that uses the ml command. If this is not possible, you can set the convergence tolerance of the maximization lower than the default value of 1e-5 by specifying the nrtolerance() option to aid in reproducibility.
Learn
Free webinars
NetCourses
Classroom and web training
Organizational training
Video tutorials
Third-party courses
Web resources
Teaching with Stata
© Copyright 1996–2024 StataCorp LLC. All rights reserved.
×
We use cookies to ensure that we give you the best experience on our website—to enhance site navigation, to analyze usage, and to assist in our marketing efforts. By continuing to use our site, you consent to the storing of cookies on your device and agree to delivery of content, including web fonts and JavaScript, from third party web services.
Cookie Settings
Last updated: 16 November 2022
StataCorp LLC (StataCorp) strives to provide our users with exceptional products and services. To do so, we must collect personal information from you. This information is necessary to conduct business with our existing and potential customers. We collect and use this information only where we may legally do so. This policy explains what personal information we collect, how we use it, and what rights you have to that information.
These cookies are essential for our website to function and do not store any personally identifiable information. These cookies cannot be disabled.
This website uses cookies to provide you with a better user experience. A cookie is a small piece of data our website stores on a site visitor's hard drive and accesses each time you visit so we can improve your access to our site, better understand how you use our site, and serve you content that may be of interest to you. For instance, we store a cookie when you log in to our shopping cart so that we can maintain your shopping cart should you not complete checkout. These cookies do not directly store your personal information, but they do support the ability to uniquely identify your internet browser and device.
Please note: Clearing your browser cookies at any time will undo preferences saved here. The option selected here will apply only to the device you are currently using.