-
Notifications
You must be signed in to change notification settings - Fork 641
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Compilation error with intel compiler #1683
Comments
Several of the emitted warnings indicate that the compiler is not actually in C++11 mode. |
The switch "-std=c++11" was definitely added to CFLAGS and CXXFLAGS before running configure script. After digging I have found that CXXFLAGS inside Makefiles was set to just "-O3", probably from mpic++ installation (mvapich2). On editing Makefile inside src subdirectory, the compilation of meep 1.19 stopped here: -- compilation aborted for structure_dump.cpp (code 2) -- |
Prevents issues with older compilers. \NanoComp#1683 NanoComp#1701
* fix factor 2 * fix * fix * fix * kpoint * fix * Fix the `binary_partition` copy constructor. (#1702) * Fix the `binary_partition` copy constructor. Prevents issues with older compilers. \#1683 #1701 * Update src/structure_dump.cpp Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> * single precision test tol * single precision test tol * Fix factor of 2 in adjoint gradients when not using complex fields (#1704) * fix factor 2 * fix * fix * fix * single precision test tol * single precision test tol * Update python/adjoint/objective.py Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Mo Chen <mochen@Mos-MacBook-Pro.local> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> * assertVectorsClose works for scalars as well as vectors (#1712) * assertVectorsClose works for scalars as well as vectors * rename ApproxComparisonMixin -> ApproxComparisonTestCase, since it is a subclass of TestCase, and use it as such * add --with-coverage to control usage of Python coverage tests (#1713) * add --with-coverage to control usage of Python coverage tests * move --with-coverage to correct CI line * flush subnormals on x86 (#1709) * flush subnormals on x86 * less aggressive error threshold in single precision * increase single-precision tolerance * update tols in test_array_metadata * update for assertVectorsClose rename * lower tolerance in single precision * Lower tolerance of CW and eigenfrequency solver tests for single precision (#1714) * lower tolerance of CW and eigenfrequency solver tests for single precision * remove change in default argument from Python wrappers * fix factor 2 * fix * kpoint * fix * single precision test tol * single precision test tol * using real * using real * fix rebase * fix * fix Co-authored-by: Mo Chen <mochen@Mos-MacBook-Pro.local> Co-authored-by: Andreas Hoenselaar <ahoens@google.com> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Ardavan Oskooi <ardavano@google.com>
* Fix the `binary_partition` copy constructor. Prevents issues with older compilers. \NanoComp#1683 NanoComp#1701 * Update src/structure_dump.cpp Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Steven G. Johnson <stevenj@mit.edu>
* fix factor 2 * fix * fix * fix * kpoint * fix * Fix the `binary_partition` copy constructor. (NanoComp#1702) * Fix the `binary_partition` copy constructor. Prevents issues with older compilers. \NanoComp#1683 NanoComp#1701 * Update src/structure_dump.cpp Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> * single precision test tol * single precision test tol * Fix factor of 2 in adjoint gradients when not using complex fields (NanoComp#1704) * fix factor 2 * fix * fix * fix * single precision test tol * single precision test tol * Update python/adjoint/objective.py Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Mo Chen <mochen@Mos-MacBook-Pro.local> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> * assertVectorsClose works for scalars as well as vectors (NanoComp#1712) * assertVectorsClose works for scalars as well as vectors * rename ApproxComparisonMixin -> ApproxComparisonTestCase, since it is a subclass of TestCase, and use it as such * add --with-coverage to control usage of Python coverage tests (NanoComp#1713) * add --with-coverage to control usage of Python coverage tests * move --with-coverage to correct CI line * flush subnormals on x86 (NanoComp#1709) * flush subnormals on x86 * less aggressive error threshold in single precision * increase single-precision tolerance * update tols in test_array_metadata * update for assertVectorsClose rename * lower tolerance in single precision * Lower tolerance of CW and eigenfrequency solver tests for single precision (NanoComp#1714) * lower tolerance of CW and eigenfrequency solver tests for single precision * remove change in default argument from Python wrappers * fix factor 2 * fix * kpoint * fix * single precision test tol * single precision test tol * using real * using real * fix rebase * fix * fix Co-authored-by: Mo Chen <mochen@Mos-MacBook-Pro.local> Co-authored-by: Andreas Hoenselaar <ahoens@google.com> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Ardavan Oskooi <ardavano@google.com>
* Fix the `binary_partition` copy constructor. Prevents issues with older compilers. \NanoComp#1683 NanoComp#1701 * Update src/structure_dump.cpp Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Steven G. Johnson <stevenj@mit.edu>
* fix factor 2 * fix * fix * fix * kpoint * fix * Fix the `binary_partition` copy constructor. (NanoComp#1702) * Fix the `binary_partition` copy constructor. Prevents issues with older compilers. \NanoComp#1683 NanoComp#1701 * Update src/structure_dump.cpp Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> * single precision test tol * single precision test tol * Fix factor of 2 in adjoint gradients when not using complex fields (NanoComp#1704) * fix factor 2 * fix * fix * fix * single precision test tol * single precision test tol * Update python/adjoint/objective.py Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Mo Chen <mochen@Mos-MacBook-Pro.local> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> * assertVectorsClose works for scalars as well as vectors (NanoComp#1712) * assertVectorsClose works for scalars as well as vectors * rename ApproxComparisonMixin -> ApproxComparisonTestCase, since it is a subclass of TestCase, and use it as such * add --with-coverage to control usage of Python coverage tests (NanoComp#1713) * add --with-coverage to control usage of Python coverage tests * move --with-coverage to correct CI line * flush subnormals on x86 (NanoComp#1709) * flush subnormals on x86 * less aggressive error threshold in single precision * increase single-precision tolerance * update tols in test_array_metadata * update for assertVectorsClose rename * lower tolerance in single precision * Lower tolerance of CW and eigenfrequency solver tests for single precision (NanoComp#1714) * lower tolerance of CW and eigenfrequency solver tests for single precision * remove change in default argument from Python wrappers * fix factor 2 * fix * kpoint * fix * single precision test tol * single precision test tol * using real * using real * fix rebase * fix * fix Co-authored-by: Mo Chen <mochen@Mos-MacBook-Pro.local> Co-authored-by: Andreas Hoenselaar <ahoens@google.com> Co-authored-by: Steven G. Johnson <stevenj@mit.edu> Co-authored-by: Ardavan Oskooi <ardavano@google.com>
With meep-1.19 Intel compiler stops with following:
--
CXX sphere-quad.o
CXXLD sphere_quad
CXX array_slice.lo
In file included from meep.hpp(25),
from meep_internals.hpp(20),
from array_slice.cpp(27):
meep/vec.hpp(306): warning #3497: standard attribute syntax is a C++11 feature
[[noreturn]] extern void abort(const char *, ...); // mympi.cpp
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(818): error: qualified name is not allowed
std::unique_ptr<binary_partition> bp;
^
In file included from meep_internals.hpp(20),
from #array_slice.cpp(27):
meep.hpp(818): error #77: this declaration has no storage class or type specifier
std::unique_ptr<binary_partition> bp;
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(818): error: expected a ";"
std::unique_ptr<binary_partition> bp;
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(822): error: namespace "std" has no member "unique_ptr"
std::unique_ptr<binary_partition> choose_chunkdivision(grid_volume &gv, volume &v, int num_chunks,
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(822): error: expected a ";"
std::unique_ptr<binary_partition> choose_chunkdivision(grid_volume &gv, volume &v, int num_chunks,
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(1407): warning #3495: rvalue references are a C++11 feature
void add_source(field_type ft, src_vol &&src);
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(2183): error: namespace "std" has no member "unique_ptr"
binary_partition(const split_plane &_split_plane, std::unique_ptr<binary_partition> &&left_tree,
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(2183): error: expected a ")"
binary_partition(const split_plane &_split_plane, std::unique_ptr<binary_partition> &&left_tree,
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(2200): error: qualified name is not allowed
std::unique_ptr<binary_partition> left;
^
In file included from meep_internals.hpp(20),
from array_slice.cpp(27):
meep.hpp(2200): error #77: this declaration has no storage class or type specifier
std::unique_ptr<binary_partition> left;
^
This error was inintroduced after meep-1.18.
I tried versions intel-2017.2.174 and intel-2019.0.117 with -std=c++11 option.
The text was updated successfully, but these errors were encountered: