12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- # StarPU --- Runtime system for heterogeneous multicore architectures.
- #
- # Copyright (C) 2020 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
- #
- # StarPU is free software; you can redistribute it and/or modify
- # it under the terms of the GNU Lesser General Public License as published by
- # the Free Software Foundation; either version 2.1 of the License, or (at
- # your option) any later version.
- #
- # StarPU is distributed in the hope that it will be useful, but
- # WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- #
- # See the GNU Lesser General Public License in COPYING.LGPL for more details.
- #
- include("nbody_display.jl")
- function mod2(v ::Vector{Float64})
- return sqrt(v[1]^2 + v[2]^2)
- end
- function compute_accelerations(positions ::Vector{Vector{Float64}}, accelerations ::Vector{Vector{Float64}}, masses ::Vector{Float64}, eps ::Float64)
- G ::Float64 = 6.67E-11
- n ::Int64 = length(accelerations)
- for i = 1:n
- sumacc ::Vector{Float64} = [0,0]
- for j = 1:n
- if i != j
- dv ::Vector{Float64} = positions[j] - positions[i]
-
- sumacc = sumacc + G * masses[j] * dv / (mod2(dv) + eps)^3
- end
- end
- accelerations[i] = sumacc
- end
- end
- function update_pos_vel(positions ::Vector{Vector{Float64}}, velocities ::Vector{Vector{Float64}}, accelerations ::Vector{Vector{Float64}}, dt ::Float64)
- n ::Int64 = length(positions)
- for i = 1:n
- velocities[i] = velocities[i] + accelerations[i] * dt
- positions[i] = positions[i] + velocities[i] * dt
- end
- end
- function nbody_jl(positions ::Vector{Vector{Float64}}, velocities ::Vector{Vector{Float64}}, accelerations ::Vector{Vector{Float64}}, masses ::Vector{Float64}, nbr_simulations ::Int64, eps ::Float64, dt ::Float64)
- for i = 1:nbr_simulations
- compute_accelerations(positions, accelerations, masses, eps)
- update_pos_vel(positions, velocities, accelerations,dt)
- # pixels ::Array{Array{Int64}} = [[0,0,0] for i = 1:1000*1000]
- # graph_planets(pixels, positions, -4E8, 4E8, 1000, 1000, "nbody$i.ppm")
- end
- end
|