Skip to content
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

Update rebound interface to Rebound release version 4.0.1 #1019

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
59 changes: 32 additions & 27 deletions src/amuse/community/rebound/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,37 @@ OBJS = interface.o

CODELIB = src/librebound.a
CODEDIR = src/rebound
LIB_OBJ = $(CODEDIR)/src/rebound.o $(CODEDIR)/src/tree.o $(CODEDIR)/src/particle.o $(CODEDIR)/src/gravity.o \
$(CODEDIR)/src/integrator.o $(CODEDIR)/src/integrator_whfast.o $(CODEDIR)/src/integrator_whfasthelio.o \
$(CODEDIR)/src/integrator_ias15.o $(CODEDIR)/src/integrator_sei.o $(CODEDIR)/src/integrator_leapfrog.o \
$(CODEDIR)/src/integrator_hermes.o $(CODEDIR)/src/boundary.o \
$(CODEDIR)/src/collision.o $(CODEDIR)/src/tools.o \
$(CODEDIR)/src/communication_mpi.o $(CODEDIR)/src/display.o $(CODEDIR)/src/derivatives.o \
$(CODEDIR)/src/glad.o $(CODEDIR)/src/integrator_janus.o $(CODEDIR)/src/transformations.o \
$(CODEDIR)/src/simulationarchive.o $(CODEDIR)/src/output.o \
$(CODEDIR)/src/input.o \
LIB_OBJ = \
$(CODEDIR)/src/rebound.o \
$(CODEDIR)/src/tree.o \
$(CODEDIR)/src/particle.o \
$(CODEDIR)/src/gravity.o \
$(CODEDIR)/src/integrator.o \
$(CODEDIR)/src/integrator_whfast.o \
$(CODEDIR)/src/integrator_whfast512.o \
$(CODEDIR)/src/integrator_saba.o \
$(CODEDIR)/src/integrator_ias15.o \
$(CODEDIR)/src/integrator_sei.o \
$(CODEDIR)/src/integrator_bs.o \
$(CODEDIR)/src/integrator_leapfrog.o \
$(CODEDIR)/src/integrator_mercurius.o \
$(CODEDIR)/src/integrator_eos.o \
$(CODEDIR)/src/boundary.o \
$(CODEDIR)/src/input.o \
$(CODEDIR)/src/binarydiff.o \
$(CODEDIR)/src/output.o \
$(CODEDIR)/src/collision.o \
$(CODEDIR)/src/communication_mpi.o \
$(CODEDIR)/src/display.o \
$(CODEDIR)/src/tools.o \
$(CODEDIR)/src/rotations.o \
$(CODEDIR)/src/derivatives.o \
$(CODEDIR)/src/simulationarchive.o \
$(CODEDIR)/src/glad.o \
$(CODEDIR)/src/integrator_janus.o \
$(CODEDIR)/src/transformations.o \
$(CODEDIR)/src/fmemopen.o \
$(CODEDIR)/src/server.o

DOWNLOAD_FROM_WEB = $(PYTHON) ./download.py
PATCH_FILES = $(PYTHON) ./patch_files.py
Expand All @@ -39,25 +61,8 @@ AM_CFLAGS = -I$(AMUSE_DIR)/lib/amuse_mpi

all: rebound_worker

DOWNLOAD_CODES?=1

ifdef DOWNLOAD_CODES
$(CODEDIR)/Makefile:
make -C . download
else
$(CODEDIR)/Makefile:
@echo ""
@echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
@echo ""
@echo "DOWNLOAD_CODES is not set. Rebound will not be downloaded and built."
@echo "If you do want Rebound, set DOWNLOAD_CODES to 1."
@echo "bash> export DOWNLOAD_CODES=1"
@echo "csh> setenv DOWNLOAD_CODES 1"
@echo ""
@echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
@echo ""
@make -s --no-print-directory -C . raise_error
endif

download:
$(RM) -Rf .pc
Expand Down Expand Up @@ -85,7 +90,7 @@ distclean:
$(RM) -Rf .pc

$(CODELIB): $(CODEDIR)/Makefile
make -C $(CODEDIR) all CC=$(CC)
make -C $(CODEDIR) librebound CC=$(CC)
ar rv $(CODELIB) $(LIB_OBJ)
ranlib $(CODELIB)

Expand Down
80 changes: 48 additions & 32 deletions src/amuse/community/rebound/download.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,75 +2,91 @@

import subprocess
import os
import sys
import time
import argparse
import urllib.request
import urllib.parse
import urllib.error
from optparse import OptionParser
from shutil import which


class GetCodeFromHttp(object):
url_template = "https://github.com/hannorein/rebound/archive/{version}.tar.gz"
class GetCodeFromHttp:
filename_template = "{version}.tar.gz"
version = ""
name = ["rebound"]
url_template = [
"https://github.com/hannorein/rebound/archive/{version}.tar.gz"
]
version = [
"",
]

def directory(self):
return os.path.abspath(os.path.dirname(__file__))

def src_directory(self):
return os.path.join(self.directory(), "src")

def unpack_downloaded_file(self, filename):
print("unpacking", filename)
def unpack_downloaded_file(self, filename, name, version):
print(f"unpacking {filename}")
arguments = ["tar", "-xf"]
arguments.append(filename)
subprocess.call(arguments, cwd=os.path.join(self.src_directory()))
subprocess.call(
["mv", "rebound-{version}".format(version=self.version), "rebound"],
["mv", f"{name}-{version}", name],
cwd=os.path.join(self.src_directory()),
)
print("done")

def start(self):
if os.path.exists("src"):
counter = 0
while os.path.exists("src.{0}".format(counter)):
while os.path.exists(f"src.{counter}"):
counter += 1
if counter > 100:
print("too many backup directories")
break
os.rename("src", "src.{0}".format(counter))
os.rename("src", f"src.{counter}")

os.mkdir("src")

url = self.url_template.format(version=self.version)
filename = self.filename_template.format(version=self.version)
filepath = os.path.join(self.src_directory(), filename)
print("downloading version", self.version, "from", url, "to", filename)
urllib.request.urlretrieve(url, filepath)
print("downloading finished")
self.unpack_downloaded_file(filename)
for i, url_template in enumerate(self.url_template):
url = url_template.format(version=self.version[i])
filename = self.filename_template.format(version=self.version[i])
filepath = os.path.join(self.src_directory(), filename)
print(f"downloading version {self.version[i]} from {url} to {filename}")
if which("wget") is not None:
arguments = ["wget", url]
subprocess.call(arguments, cwd=os.path.join(self.src_directory()))
elif which("curl") is not None:
arguments = ["curl", "-L", "-O", url]
subprocess.call(arguments, cwd=os.path.join(self.src_directory()))
else:
urllib.request.urlretrieve(url, filepath)
print("downloading finished")
self.unpack_downloaded_file(filename, self.name[i], self.version[i])


def new_argument_parser():
result = argparse.ArgumentParser()
result.add_argument(
"--rebound-version",
default="111bcd50de54e4cc70e1d4915918226a4adbe188",
# default="4df2b4603058e7d767aee9c26b586b55a5f4de65",
dest="rebound_version",
help="Rebound commit hash to download",
type=str,
)
return result


def main(version=""):
arguments = new_argument_parser().parse_args()
version = [
arguments.rebound_version,
]
instance = GetCodeFromHttp()
instance.version = version
instance.start()


def new_option_parser():
result = OptionParser()
result.add_option(
"--version",
default="31d117bdc92182073d0941c331f76e95f515bfc6",
dest="version",
help="version number to download",
type="string",
)
return result


if __name__ == "__main__":
options, arguments = new_option_parser().parse_args()
main(**options.__dict__)
main()
Loading
Loading