-
Notifications
You must be signed in to change notification settings - Fork 301
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
library(sf) loads wrong version of GEOS #844
Comments
I've seen the same thing when testing against 3.7.0rc2, after Brian Ripley warned @rsbivand (rgeos) and me about it a few days ago. Will try again with 3.7.0. Big mystery! |
I reproduced it again (in a container) with GEOS 3.7.0, and got the same error. In earlier attempts I tried to remove |
@edzer I'm able to build and run a dummy program using
with
|
Running
Yet, running the following:
|
The link step of rgeos is
which includes |
adding this didn't solve the problem. |
After moving |
Yes, multiple libgeos will probably cause havoc. I haven't seen any rgeos issues on Fedora, but always delete earlier /usr/local/lib/libgeos* etc., and never let any packager install GDAL, PROJ or GEOS. The warning from Brian Ripley may relate to static builds (
and
Please advise on any need to change |
rgeos
|
|
But it removes the version suffix from the rgeos link step. Beyond that, the loader will use the first libgeom it finds. I'm not seeing any issues on Fedora, feels like a platform issue. Time someone made a Fedora rocker for improved stability? |
I think the issue Can't build against GEOS 3.7.0 is not true; the issue Can't build against GEOS 3.7.0 if there is also another GEOS installation on my system is, depending on where it is. Some diagnostics: When hacking geos.cpp such that it doesn't use symbols provided only by GEOS 3.7.0 or 3.6.1, it compiles AND loads on R when GEOS 3.7.0 is in /usr/local/lib and GEOS 3.5.1 (or so) is in /usr/lib/something. Then:
but after starting R:
A hacky solution to this might be
but I'm not sure if I would go as far as recommending this to anyone. It would actually be good (sane, secure) to do a run-time check that the GEOS version linked to corresponds to the one found at compile time. |
In rgdal this is done on attach (maybe should be done on load?) using |
Gives me: > library(sf)
Linking to GEOS 3.7.0, GDAL 2.4.0dev-358fa65, proj.4 5.1.0
WARNING: different compile-time and runtime versions for GEOS I'll try to improve this: the linking to GEOS info is wrong. |
Gives:
|
I've committed to rgeos as r576, but found that my loader itself stopped the package loading when the versions differed:
but had replaced 3.7.0 with 3.6.3. In your case, I assume that both were present but libgeos was linked to another version? |
Yes, it is more likely to get a load error than a version mismatch warning, but nevertheless useful to check IMO. In my case both are present and in |
@edzer Yes, it seems it's really an issue with R itself, not |
Everything works ok if I explicitly load GEOS before sf, with:
But putting a |
Thanks! Now that we know all this, I'm thinking about writing a short wiki entry, and make a link to it from the README.md file. |
@edzer I'm running into similar issues, any progress on the wiki entry to help describe this issue or how to avoid it? |
Some R libraries like sf have bugs detecting gdal unless this is in the LD_LIBRARY_PATH. See: r-spatial/sf#844
I know this is a closed issue, so this comment might not be seen... but this is the closest discussion I've found that matches my problem. I work in an enterprise environment where R is installed on a single server, and we all access it via RStudio Server Pro. I have no control, then, over the various versions of things, and have resorted to installing newer versions of key libraries in my home directory, while adjusting PATH and LD_LIBRARY_PATH as appropriate. This hasn't caused me any problems whatsoever until I installed newer versions of GEOS, GDAL and Proj. Our server has GEOS 3.5.1 (and GDAL 2.1.x), and I have installed GEOS 3.8.1 (and GDAL 3.1.1) in my home directory. Basically, I now can't install rgeos, or any other package that depends on GEOS, in the usual way. During configuration and build, rgeos very clearly uses GEOS 3.8.1, but it seems that R tries to load 3.5.1 during checks, and only during checks. I can get a correctly functioning rgeos that uses my personal GEOS installation if I install via: R CMD INSTALL rgeos_0.5-3.tar.gz --no-test-load I also then have to install any other package that depends on GEOS using this same method, but the installed package always works correctly. It's driving me crazy and I hoped somebody with a better understanding of the load hooks knows why R was loading the wrong GEOS library, but only during package install tests. Anyway, if anybody sees this, I'd be grateful for any suggestions; and I'll look for an rgeos forum to post this also. |
You need to set |
Thanks for the very fast response. I did see that comment, but I had checked |
I think I'll just have to admit defeat...
|
@cmhh does loading GEOS explicitly not work for you, like here? #844 (comment) I added this line to my |
@dbaston No it didn't. That is to say, I can install using the method described above (setting export LD_DEBUG=libs
R CMD INSTALL rgeos_0.5-3.tar.gz and here's a chunk of the output:
I have set |
@dbaston Hold the phone... it seems my
Thanks! |
Had a lot of trouble getting 'sf' package to install on Red Hat/CentOS 7: I first tried to run I then ran the following to install a newer version (following instructions from somewhere I do not recall): and installed GDAL from source: Compile from source then the installer (running as Now appears to be installed and working. I found this issue page via https://github.com/r-spatial/sf, but that page doesn't include CentOS 7 install steps. Would be nice to add CentOS steps to that page. |
@rsbivand Confirming that removing older libgeos files in /usr/local/lib resolved dynamic library load test failure at the end of the build process for packages sf and rgdal on Ubuntu 20.04 |
This is perhaps off target, but may be related. I raise it here both to ask for advice and to flag that I believe that the issue is created by following the standard installion instructions for sf and QGIS... My situation I have sf working fine on Ubuntu 20.04.4 LTS, but I'm having problems with my QGIS installation. I think this is because of multiple libproj installations (see here for details of the issue I think I have).
./usr/lib/x86_64-linux-gnu/libproj.a How this came to be I believe installing QGIS created the initial ./usr/lib/x86_64-linux-gnu/ I then installed sf, but my understanding is that sf needs the -dev version, so must have created the ./usr/share/doc/ versions It's at this point that QGIS stopped finding PROJ... I suspect I then somehow created the second ./usr/lib/x86_64-linux-gnu/ version trying to fix QGIS not finding PROJ (I first took the error literally and thought it was not installed)... My question(s) I want to fix QGIS without breaking sf... I clearly need to delete a few versions to fix QGIS, but which one is sf using? Am I correct in saying that sf will be using ./usr/share/doc/libproj-dev? Alternatively, how do I find out which one sf is using? Should I delete ./usr/share/doc/libproj15 and ./usr/share/doc/libproj22 or keep all 3 in that location? My temptation is to delete all the ./usr/lib/x86_64-linux-gnu/ versions and hope for the best? Any suggestions greatly appreciated! Thanks! |
Hello! I'm having the same issue as in these posts, yet am using RedHat 8, and cannot use some of the suggested solutions. I have deleted any gdal instance I can find on the server and reinstalled several times to no avail. So far, my primary attempts have gone like this:
And in
Any help on where to look for duplicated gdal instances would be much appreciated. I have deleted as many as I can |
I think that |
The use of the PROJ function is guarded by Line 194 in e45ceca
HAVE_71 from Lines 17 to 25 in e45ceca
|
Thank you @rsbivand . Your answer helped very much. For whatever reason the I followed this tutorial on installing the geospatial libraries from source, which was quite helpful and includes some troubleshooting options: https://docs.djangoproject.com/en/4.2/ref/contrib/gis/install/geolibs/ And I modified the
Thanks! |
Hi, I have a quick question related to the issues in this post. I've just installed sf() on R 4.3.1, but some of the last lines of the installation output say:
My question is if those are warnings that something went wrong somewhere. Don't know, but it sounds strange that there are no definitions for class "Spatial" and other classes. sf() does load, however:
but I'm unsure of whether it is going to work properly or will have problems in the future. I have been using sf() for a while and had not noticed those (potential) warnings before, so perhaps they always show up? I've seen multiple posts with the same messages for people who had trouble installing sf() [e.g. @McAllister-NOAA's recent question] but decided to ask here precisely because this thread was active very recently. @McAllister-NOAA, did you get those messages/warnings during your recent successful installation of sf()? If so, is sf() behaving normal? Thanks! |
Those are installation messages, nothing to worry about, and completely unrelated to the issue your link to. |
Good to know, thanks! |
I get the following error when building
sf
master against GEOS 3.7.0:I verified that the symbol is present in
libgeos_c.so
:The following command is used to link
sf
:g++ -std=gnu++11 -shared -L/usr/lib/R/lib -Wl,-Bsymbolic-functions -Wl,-z,relro -o sf.so RcppExports.o bbox.o gdal.o gdal_geom.o gdal_read.o gdal_utils.o gdal_write.o geos.o hex.o proj.o raster2sf.o sfg.o signed_area.o stars.o wkb.o -lproj -L/usr/local/lib -lgdal -L/usr/local/lib -lgeos_c -L/usr/lib/R/lib -lR
which looks right to me.
The text was updated successfully, but these errors were encountered: