2019-10-31 14:32:46 -04:00
// Copyright (C) 2018 spdfg
2018-10-06 20:03:14 -07:00
//
// This file is part of Elektron.
//
// Elektron is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Elektron 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Elektron. If not, see <http://www.gnu.org/licenses/>.
//
2016-11-10 20:01:22 -05:00
package utilities
2016-11-25 20:21:01 -05:00
/ *
The Pair and PairList have been taken from google groups forum ,
2017-09-28 15:36:47 -04:00
https : //groups.google.com/forum/#!topic/golang-nuts/FT7cjmcL7gw.
2016-11-25 20:21:01 -05:00
* /
2016-11-10 20:01:22 -05:00
2016-12-22 23:27:18 -05:00
// Utility struct that helps in sorting map[string]float64 by value.
2016-11-10 20:01:22 -05:00
type Pair struct {
2016-11-25 17:42:08 -05:00
Key string
Value float64
2016-11-10 20:01:22 -05:00
}
// A slice of pairs that implements the sort.Interface to sort by value.
type PairList [ ] Pair
2017-09-28 15:36:47 -04:00
// Convert map[string]float64 to PairList.
2017-02-22 20:07:48 -05:00
func GetPairList ( m map [ string ] float64 ) PairList {
pl := PairList { }
for k , v := range m {
pl = append ( pl , Pair { Key : k , Value : v } )
}
return pl
}
2017-09-28 15:36:47 -04:00
// Swap pairs in the PairList.
2016-11-10 20:01:22 -05:00
func ( plist PairList ) Swap ( i , j int ) {
2016-11-25 17:42:08 -05:00
plist [ i ] , plist [ j ] = plist [ j ] , plist [ i ]
2016-11-10 20:01:22 -05:00
}
2017-09-28 15:36:47 -04:00
// Get the length of the pairlist.
2016-11-10 20:01:22 -05:00
func ( plist PairList ) Len ( ) int {
2016-11-25 17:42:08 -05:00
return len ( plist )
2016-11-10 20:01:22 -05:00
}
2017-09-28 15:36:47 -04:00
// Compare two elements in pairlist.
2016-11-10 20:01:22 -05:00
func ( plist PairList ) Less ( i , j int ) bool {
2016-11-25 17:42:08 -05:00
return plist [ i ] . Value < plist [ j ] . Value
2016-11-10 20:01:22 -05:00
}