Class: Orbiter::Orbit_runner

Inherits:
Object
  • Object
show all
Defined in:
lib/orbiter.rb

Class Method Summary collapse

Class Method Details

.run(attrs = {}) ⇒ Object



7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# File 'lib/orbiter.rb', line 7

def self.run(attrs = {})
	@bodies = attrs.fetch(:bodies, [Orbiter::Free_body.new(mass: 10, x: 100, y: 100, vel_x: -5, vel_y: -1),
																	Orbiter::Free_body.new(mass:1000)])
	@output = attrs[:output] ? File.open(attrs[:output], 'w') : $stdout
	
	100.times do 
		@bodies.each do |body|
			Orbiter::Orbit_updater.calc_grav_acc(body, @bodies)
			Orbiter::Orbit_updater.update_position(body)
			Orbiter::Orbit_updater.calc_grav_acc(body, @bodies)
			Orbiter::Orbit_updater.update_velocity(body)
		end
		Orbiter::Orbit_updater.track(@output, @bodies)
	end
	
	@output.close

	puts "Thanks for running!"
end