fix edge case where a routes first way was upside down

This commit is contained in:
Araozu 2024-09-10 17:40:32 -05:00
parent 753652542c
commit 641624d238

62
main.go
View File

@ -122,6 +122,12 @@ func main() {
} }
log.Println("XML unmarshal finished") log.Println("XML unmarshal finished")
// Create a map of IDs to Nodes
nodesMap := make(map[int64]*OsmNode)
for _, node := range osmDocument.Nodes {
nodesMap[node.Id] = &node
}
// Get the relation with id 17642638, // Get the relation with id 17642638,
// that relation hosts the SIT data // that relation hosts the SIT data
var sitId int64 = 17642638 var sitId int64 = 17642638
@ -181,7 +187,7 @@ func main() {
// Convert each CombiData into a CombiRoute and store it // Convert each CombiData into a CombiRoute and store it
for idx, combi := range combis { for idx, combi := range combis {
if idx > 0 { if idx > 10 {
break break
} }
@ -189,7 +195,7 @@ func main() {
returnCoord := make([][]float64, 0) returnCoord := make([][]float64, 0)
combiRoute := CombiRoute{ combiRoute := CombiRoute{
Name: combi.Ref, Name: combi.Ref,
Departure: getCoordinates(&osmDocument.Ways, &osmDocument.Nodes, combi.Members), Departure: getCoordinates(&osmDocument.Ways, nodesMap, combi.Members),
Return: &returnCoord, Return: &returnCoord,
} }
combiLineSlice := combiRoutesMap[combi.Id] combiLineSlice := combiRoutesMap[combi.Id]
@ -199,7 +205,7 @@ func main() {
writeOutput(combiLineMap, combiRoutesMap) writeOutput(combiLineMap, combiRoutesMap)
} }
func getCoordinates(ways *[]OsmWay, nodes *[]OsmNode, membersSlice *[]OsmMember) *[][]float64 { func getCoordinates(ways *[]OsmWay, nodes map[int64]*OsmNode, membersSlice *[]OsmMember) *[][]float64 {
coordinates := make([][]float64, 0) coordinates := make([][]float64, 0)
// The coordinate list may be reversed // The coordinate list may be reversed
@ -210,6 +216,7 @@ func getCoordinates(ways *[]OsmWay, nodes *[]OsmNode, membersSlice *[]OsmMember)
// without duplicates // without duplicates
orderedCoordinates := make([]*OsmNode, 0) orderedCoordinates := make([]*OsmNode, 0)
var previousNodeId int64 = -1 var previousNodeId int64 = -1
var previousWayId int64 = -1
// get all coordinates from each // get all coordinates from each
for _, member := range *membersSlice { for _, member := range *membersSlice {
@ -227,11 +234,15 @@ func getCoordinates(ways *[]OsmWay, nodes *[]OsmNode, membersSlice *[]OsmMember)
if previousNodeId == -1 { if previousNodeId == -1 {
// just add all // just add all
secondWay := findOsmway((*membersSlice)[1].Ref, ways)
coords = findFirstCoord(way, secondWay, nodes)
for _, c := range coords { for _, c := range coords {
orderedCoordinates = append(orderedCoordinates, c) orderedCoordinates = append(orderedCoordinates, c)
} }
// keep track of the last id // keep track of the last id
previousNodeId = coords[coordsLen-1].Id previousNodeId = coords[coordsLen-1].Id
previousWayId = way.Id
} else if coords[0].Id == previousNodeId { } else if coords[0].Id == previousNodeId {
// check if the first coordinate is the same as the previous stored // check if the first coordinate is the same as the previous stored
// if so, add them except the first one, // if so, add them except the first one,
@ -242,6 +253,7 @@ func getCoordinates(ways *[]OsmWay, nodes *[]OsmNode, membersSlice *[]OsmMember)
// keep track of the last id // keep track of the last id
previousNodeId = coords[coordsLen-1].Id previousNodeId = coords[coordsLen-1].Id
previousWayId = way.Id
} else if coords[coordsLen-1].Id == previousNodeId { } else if coords[coordsLen-1].Id == previousNodeId {
// if not, they are reversed // if not, they are reversed
// add all except the last // add all except the last
@ -251,8 +263,9 @@ func getCoordinates(ways *[]OsmWay, nodes *[]OsmNode, membersSlice *[]OsmMember)
// keep track of the last id // keep track of the last id
previousNodeId = coords[0].Id previousNodeId = coords[0].Id
previousWayId = way.Id
} else { } else {
log.Fatalf("Found a way whose ends didn't connect to the previous way. Expected to find %d in way with id %d", previousNodeId, way.Id) log.Fatalf("Found a way that didn't connect to the previous way. Expected to find node(%d) in way(%d), the previous way id is (%d)", previousNodeId, way.Id, previousWayId)
} }
} }
@ -267,18 +280,43 @@ func getCoordinates(ways *[]OsmWay, nodes *[]OsmNode, membersSlice *[]OsmMember)
return &coordinates return &coordinates
} }
func findNode(id int64, nodes *[]OsmNode) *OsmNode { func findFirstCoord(firstWay, secondWay *OsmWay, nodes map[int64]*OsmNode) []*OsmNode {
var coordinateNode *OsmNode // find the common point
for _, newNode := range *nodes { first := make([]*OsmNode, 0)
if newNode.Id == id { for _, node := range firstWay.Nds {
coordinateNode = &newNode coordinate := findNode(node.Ref, nodes)
first = append(first, coordinate)
} }
firstLast := len(first) - 1
second := make([]*OsmNode, 0)
for _, node := range secondWay.Nds {
coordinate := findNode(node.Ref, nodes)
second = append(second, coordinate)
} }
if coordinateNode == nil { secondLast := len(second) - 1
log.Fatalf("Node with id %s not found", id)
if first[firstLast].Id == second[0].Id || first[firstLast].Id == second[secondLast].Id {
return first
} else if first[0].Id == second[0].Id || first[0].Id == second[secondLast].Id {
// reverse the slice
newFirst := make([]*OsmNode, len(first))
for i := 0; i < len(first); i += 1 {
newFirst[i] = first[firstLast-i]
} }
return coordinateNode return newFirst
} else {
log.Fatalf("Could not find 2 points in common between 2 ways with ids %d & %d", firstWay.Id, secondWay.Id)
panic("")
}
}
func findNode(id int64, nodes map[int64]*OsmNode) *OsmNode {
node := nodes[id]
if node == nil {
log.Fatalf("Node with id %s not found", id)
}
return node
} }
func findOsmway(id int64, ways *[]OsmWay) *OsmWay { func findOsmway(id int64, ways *[]OsmWay) *OsmWay {