aboutsummaryrefslogtreecommitdiffstats
path: root/simulation/network-model.go
blob: 01704e71bb06b64d4f6df78fe277c9f0495bbcc9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// Copyright 2018 The dexon-consensus-core Authors
// This file is part of the dexon-consensus-core library.
//
// The dexon-consensus-core library 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 3 of the License,
// or (at your option) any later version.
//
// The dexon-consensus-core library 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 for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with the dexon-consensus-core library. If not, see
// <http://www.gnu.org/licenses/>.

package simulation

import (
    "math/rand"
    "time"
)

// Model is the interface for define a given network environment.
type Model interface {
    // LossRate returns the message lost ratio between [0, 1)
    LossRate() float64

    // Delay returns the send delay of the message.  This function is called each
    // time before the message is sent, so one can return different number each
    // time.
    Delay() time.Duration
}

// LosslessNetwork is a lossless network model.
type LosslessNetwork struct {
}

// LossRate returns lossrate for the model.
func (l *LosslessNetwork) LossRate() float64 {
    return 0.0
}

// Delay returns the send delay of a given message.
func (l *LosslessNetwork) Delay() time.Duration {
    return time.Duration(0)
}

// FixedLostNoDelayModel is a network with no delay and a fixed lost
// ratio.
type FixedLostNoDelayModel struct {
    LossRateValue float64
}

// LossRate returns lossrate for the model.
func (f *FixedLostNoDelayModel) LossRate() float64 {
    return f.LossRateValue
}

// Delay returns the send delay of a given message.
func (f *FixedLostNoDelayModel) Delay() time.Duration {
    return time.Duration(0)
}

// NormalNetwork is a model where it's delay is a normal distribution.
type NormalNetwork struct {
    Sigma         float64
    Mean          float64
    LossRateValue float64
}

// LossRate returns lossrate for the model.
func (n *NormalNetwork) LossRate() float64 {
    return n.LossRateValue
}

// Delay returns the send delay of a given message.
func (n *NormalNetwork) Delay() time.Duration {
    delay := rand.NormFloat64()*n.Sigma + n.Mean
    if delay < 0 {
        delay = n.Sigma / 2
    }
    return time.Duration(delay) * time.Millisecond
}