layout | title | permalink |
---|---|---|
default |
FAQ |
faq.html |
Say "MAY-sa".
Yes. It is available in a variety of sizes for your convenience.
The picture shows the intense authors hard at work making final edits.
A late night session working on the first MESA paper around Bill's dining room table with a projector, a makeshift screen, and ample red wine (left to right, Frank Timmes, Aaron Dotter, Falk Herwig, Lars Bildsten, and Bill Paxton). Photo taken by Bill's patient wife, Kathlyn, who deserves a great deal of credit for the existence of MESA.
By the fifth MESA paper, there's a bigger room and a better screen. Left-to-right: Aaron Dotter, Jared Goldberg, Lars Bildsten, Radek Smolec, Anne Thoul, Bill Paxton, Adam Jermyn, Josiah Schwab, Frank Timmes, Croissants, Rich Townsend, Coffee, and Pablo Marchant. Photo taken by Matteo Cantiello.
As MESA evolves, inlist options, variable names, and other aspects of the code change in ways that are not backward-compatible. Here is a list of some of the major renaming events; it is by no means exhaustive. Consult the release notes for these versions for more information.
- r4411: major renaming and reorganization of the code
- r8118: renaming and restructuring of controls related to winds.
run_star_extras
routines changed to hooks. - r8845: most names using "cnt" were changed to use "interval" (e.g.,
terminal_cnt
was renamed toterminal_interval
). the optionphotostep
was renamed tophoto_interval
. One exception isAbundance_legend_max_cnt
which remained unchanged since it is not an interval between events.
MESA is no longer supported on 32-bit systems. This isn't by design; we simply haven't been able to get it to work! So if you REALLY want to use an antique 32-bit system for MESA, you'll have to try to make it work yourself.
{% include releases.html %}
The MESA zipfiles are large (~1GB), so if you're on a slow connection, there's nothing to be done. However, users have reported substantial variations in download speed from the sourceforge site. If you are experiencing slow download speeds, you may want to change which mirror you are using. (After you select a zipfile to download, click the "try another mirror" link near the top of the page.)
Errors like
Fatal Error: Wrong module version '7' (expected '5')
typically arise because you have changed the gfortran compiler since you last built MESA. (Sometimes a changed gfortran version is an indication that you forgot to activate the MESA SDK.) To fix, run ./clean in the MESA directory, and then try building again.
It is necessary to take the following actions on recent versions of OS X (10.9 or later) , even if you had a working version of MESA on your previous version of OS X.
-
Install or reinstall the current version of Xquartz.
-
Install the command line tools, using the command
{% highlight bash %} xcode-select --install {% endhighlight %}
- If you are using macOS 10.14 (Mojave), there has been a change in how the system headers are provided (see section "Command Line Tools" in the Xcode 10 release notes). As a workaround, Apple provides an extra package that will install the headers to the base system. At present, one must do this:
{% highlight bash %} open /Library/Developer/CommandLineTools/Packages/macOS_SDK_headers_for_macOS_10.14.pkg {% endhighlight %}
- Install the latest version of the MESA SDK appropriate for your version of OS X.
If yore using macOS 10.14 (Mojave), then this error indicates that you did not install the system headers (see previous FAQ or the SDK website).
If you receive the error
configure: error: C compiler cannot create executables
See `config.log' for more details.
during the MESA installation of crlibm, please check that you are not using an unsupported 32-bit system. If you're using macOS, make sure you've installed Xcode and the command line tools.
If you're using Linux and you see an error message in config.log like
In file included from /opt/mesasdk/lib/gcc/x86_64-pc-linux-gnu/5.3.1/include-fixed/features.h:338:0,
from /usr/include/bits/libc-header-start.h:33,
from /usr/include/stdio.h:28,
from test.c:1:
/usr/include/sys/cdefs.h:481:49: error: missing binary operator before token "("
#if __GNUC_PREREQ (4,8) || __glibc_clang_prereq (3,5)
^
In file included from test.c:1:0:
/usr/include/stdio.h:320:43: error: missing binary operator before token "("
#if defined __USE_XOPEN2K8 || __GLIBC_USE (LIB_EXT2)
^
/usr/include/stdio.h:399:17: error: missing binary operator before token "("
#if __GLIBC_USE (LIB_EXT2)
^
/usr/include/stdio.h:657:43: error: missing binary operator before token "("
#if defined __USE_XOPEN2K8 || __GLIBC_USE (LIB_EXT2)
you may need to tell gcc to regenerate its fixed header files.
You can do so with the commands:
GCC_VERSION=`gcc --version | grep ^gcc | sed 's/^.* //g'`
$MESASDK_ROOT/libexec/gcc/x86_64-pc-linux-gnu/$GCC_VERSION/install-tools/mkheaders $MESASDK_ROOT
If the error persists, please email [email protected]. Follow the instructions for posting a question to mesa-users and also attach the file $MESA_DIR/crlibm/crlibm/config.log
.
Older versions of MESA may fail to compile with more recent versions of the MESA SDK. There are two basic solutions:
(1) Use the contemporary version of the SDK. There is a list of old MESA SDKs that indicates which version of MESA was current when each was released.
(2) Fix the individual compilation errors (there are typically only a handful to work through).
Older MESA versions (r10398 or earlier) used a compiler flag that treated warnings as errors. When warnings are added in newer compiler versions, MESA fails to build.
These warnings can safely be ignored. To stop treating them as errors,
edit the file utils/makefile_header
and delete -Werror
from
FCwarn
. This should resolve error messages of the form
Error: <message> [-Werror=<warning-type>]
,
including, but not limited to:
Error: 'time0' may be used uninitialized in this function [-Werror=maybe-uninitialized]
Error: Array reference at (1) out of bounds (0 < 1) in loop beginning at (2) [-Werror=do-subscript]
Error: '__builtin_memset' specified size between 9223372036854775808 and 18446744073709551615 exceeds maximum object size 9223372036854775807 [-Werror=stringop-overflow=]
Error: Impure function 'is_inf_qp_0d' at (1) might not be evaluated [-Werror=function-elimination]
After these warning errors are eliminated, the basic workflow is
- ./install until an error turns up,
- cd to that module and edit and ./mk until it compiles, then
- go back to ./install and repeat until everything works before
- a final ./touch and ./install.
The following FAQs give examples of specific errors.
This sort of error typically occurs when using an older MESA release
with a newer SDK. To work around this, simply insert the blank space
as requested. i.e. change stop'fixup'
to stop 'fixup'
.
This sort of error typically occurs when using an older MESA release (r10398 or before) with a newer SDK (that includes gfortran 7.3 or later).
Program received signal SIGSEGV: Segmentation fault - invalid memory reference.
Backtrace for this error:
#0 0x7f28c0a93a7f in ???
#1 0x54313f in do_history_info
at ../private/history.f90:383
...
To work around this, edit $MESA_DIR/star/private/history.f90
and replace the line
{% highlight fortran %} if (open_close_log) close(io) {% endhighlight %} with
{% highlight fortran %} if (open_close_log .and. write_flag) close(io) {% endhighlight %}
Note that this only applies to this specific segfault and not segfaults in general.
Older versions of MESA (r6794 or earlier) assumed that they would be installed from the subversion repository. Therefore, if you install these versions from a zipfile, you will see messages like
svn: E155007: '/Users/fxt/mesa/mesa-r6794' is not a working copy
when you run MESA. These messages are safe to ignore.
If are using both r11701 and the MESASDK version 20190830 then you should switch to using the previous MESASDK (20190503) and re-install MESA. This is due to having a newer compiler in 20190830 than we used to release r11701, generating a bug that is not present with older compilers.
If you are not using both the MESA r11701 and the MESASDK version 20190830 and you receive this message, please email [email protected]. This is a critical error and you should not continue.
Make sure you have the option pgstar_flag = .TRUE. in the &star_job section of your input file. Also, if you're not using the SDK, make sure you enabled PGPLOT in your utils/makefile_header file (when using the SDK, PGPLOT is enabled by default).
As of the 20140713 release, the MESA SDK includes the ffmpeg encoder and a simple script, images_to_movie.sh, which uses ffmpeg to create movies from PNG files produced by MESA.
To make use of this capability, consult Rich's instructions.
Fortran. But MESA is written using advanced features of modern Fortran which make it very different from Fortran 77 codes you might have previously seen (or written!). If you are not already familiar with the new and wonderful things that have been added, there are good resources available on the web -- here's one: Fortran 95 language features.
"Thread-safe" simply means that users can take advantage of multicore processors.
For example, during stellar evolution, you need to evaluate the eos at lots of points:
{% highlight fortran %} do k = 1, num_zones call eos(T(k), rho(k), ....) end do {% endhighlight %}
Most fortran compilers (ifort and gfortran and others) support OpenMP, so the loop can be made to run in parallel by adding 2 lines of magic:
{% highlight fortran %} !$OMP PARALLEL DO PRIVATE (k) do k = 1, num_zones call eos(T(k), rho(k), ....) end do !$OMP END PARALLEL DO {% endhighlight %}
Now, if I have 4 cores, I'll have 4 threads of execution evaluating the eos.
However, for it to work, the implementation needs to be thread-safe.
In practice this means, making shared data read-only after
initialization. Working memory must be allocated from the stack (as
local variables of routines) or allocated dynamically (using
fortran95's allocate primitive). So, basically it boils down to
avoiding common blocks and save's. It's easy to arrange for this in
new code; it can be nasty converting old code however. Stellar
evolution is a good candidate for making use of many cores. Just
wrapping "parallel" directives around some loops does it if the system
is designed with that in mind -- and MESA is. But there is still much
to be done to make good use of more than 3 or 4 cores in
MESA/star.
It will be an ongoing effort to improve the design of
the code in that area; help with that is welcomed!
The easiest way to get the idea is to look at a sample, and in the MESA directory you will find a subdirectory called “sample”. Make a copy of the sample directory anywhere you’d like and give it whatever name you want. Follow the instructions in the README file to make and test the sample. You may also want to look at the following information from previous MESA summer schools:
Users have posted numerous useful scripts in a variety of languages on the MESA marketplace.
Ehsan Moravveji has developed a package available for free access on bitbucket to recompute OP opacities for any desired mixture (that MESA supports) and for any user-specified iron and nickel enhancement factors.
If you are using an address hosted at qq.com, this domain is blocked by our mail host. Due to a deluge of spam, no mail will be accepted from or delivered to qq.com.