68 lines
1.2 KiB
V
68 lines
1.2 KiB
V
module sim
|
|
|
|
import math
|
|
import benchmark
|
|
|
|
const (
|
|
max_iterations = 1000
|
|
simulation_delta_t = 0.0005
|
|
)
|
|
|
|
pub struct SimRequest {
|
|
params SimParams
|
|
state SimState
|
|
pub:
|
|
id int
|
|
}
|
|
|
|
pub struct SimResult {
|
|
state SimState
|
|
pub:
|
|
id int
|
|
magnet1_distance f64
|
|
magnet2_distance f64
|
|
magnet3_distance f64
|
|
}
|
|
|
|
pub fn sim_worker(id int, request_chan chan &SimRequest, result_channels []chan &SimResult) {
|
|
mut bmark := benchmark.new_benchmark()
|
|
for {
|
|
request := <-request_chan or { break }
|
|
bmark.step()
|
|
result := compute_result(request)
|
|
for ch in result_channels {
|
|
ch <- result
|
|
}
|
|
bmark.ok()
|
|
}
|
|
bmark.stop()
|
|
println(bmark.total_message(@FN + ': worker $id'))
|
|
}
|
|
|
|
pub fn compute_result(request SimRequest) &SimResult {
|
|
mut state := request.state
|
|
params := request.params
|
|
|
|
for _ in 0 .. sim.max_iterations {
|
|
state.increment(sim.simulation_delta_t, params)
|
|
if state.done() {
|
|
println('done!')
|
|
break
|
|
}
|
|
}
|
|
|
|
m1_dist := params.get_magnet_dist(0, state)
|
|
m2_dist := params.get_magnet_dist(2.0 * math.pi / 3.0, state)
|
|
m3_dist := params.get_magnet_dist(4.0 * math.pi / 3.0, state)
|
|
|
|
id := request.id
|
|
|
|
return &SimResult{
|
|
id: id
|
|
state: state
|
|
magnet1_distance: m1_dist
|
|
magnet2_distance: m2_dist
|
|
magnet3_distance: m3_dist
|
|
}
|
|
}
|