mirror of
https://github.com/derf/travelynx
synced 2024-12-11 13:33:00 +00:00
get name/ds100 from db and lat/lon from dict
result: significant performance improvement for stats generation
This commit is contained in:
parent
73dd23e422
commit
afedcef266
3 changed files with 89 additions and 33 deletions
|
@ -323,12 +323,13 @@ sub startup {
|
||||||
journeys => sub {
|
journeys => sub {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
state $journeys = Travelynx::Model::Journeys->new(
|
state $journeys = Travelynx::Model::Journeys->new(
|
||||||
log => $self->app->log,
|
log => $self->app->log,
|
||||||
pg => $self->pg,
|
pg => $self->pg,
|
||||||
in_transit => $self->in_transit,
|
in_transit => $self->in_transit,
|
||||||
stats_cache => $self->journey_stats_cache,
|
stats_cache => $self->journey_stats_cache,
|
||||||
renamed_station => $self->app->renamed_station,
|
renamed_station => $self->app->renamed_station,
|
||||||
stations => $self->stations,
|
latlon_by_station => $self->app->coordinates_by_station,
|
||||||
|
stations => $self->stations,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
@ -424,8 +425,7 @@ sub startup {
|
||||||
|
|
||||||
my @unknown_stations;
|
my @unknown_stations;
|
||||||
for my $station (@stations) {
|
for my $station (@stations) {
|
||||||
my $station_info
|
my $station_info = $self->stations->get_by_name($station);
|
||||||
= $self->stations->get_by_name( $station );
|
|
||||||
if ( not $station_info ) {
|
if ( not $station_info ) {
|
||||||
push( @unknown_stations, $station );
|
push( @unknown_stations, $station );
|
||||||
}
|
}
|
||||||
|
|
|
@ -1145,6 +1145,73 @@ my @migrations = (
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
# v27 -> v28
|
||||||
|
# add ds100, name, and lat/lon from stations table to journeys_str / in_transit_str
|
||||||
|
sub {
|
||||||
|
my ($db) = @_;
|
||||||
|
$db->query(
|
||||||
|
qq{
|
||||||
|
drop view journeys_str;
|
||||||
|
drop view in_transit_str;
|
||||||
|
create view journeys_str as select
|
||||||
|
journeys.id as journey_id, user_id,
|
||||||
|
train_type, train_line, train_no, train_id,
|
||||||
|
extract(epoch from checkin_time) as checkin_ts,
|
||||||
|
extract(epoch from sched_departure) as sched_dep_ts,
|
||||||
|
extract(epoch from real_departure) as real_dep_ts,
|
||||||
|
checkin_station_id as dep_eva,
|
||||||
|
dep_station.ds100 as dep_ds100,
|
||||||
|
dep_station.name as dep_name,
|
||||||
|
dep_station.lat as dep_lat,
|
||||||
|
dep_station.lon as dep_lon,
|
||||||
|
extract(epoch from checkout_time) as checkout_ts,
|
||||||
|
extract(epoch from sched_arrival) as sched_arr_ts,
|
||||||
|
extract(epoch from real_arrival) as real_arr_ts,
|
||||||
|
checkout_station_id as arr_eva,
|
||||||
|
arr_station.ds100 as arr_ds100,
|
||||||
|
arr_station.name as arr_name,
|
||||||
|
arr_station.lat as arr_lat,
|
||||||
|
arr_station.lon as arr_lon,
|
||||||
|
polylines.polyline as polyline,
|
||||||
|
cancelled, edited, route, messages, user_data,
|
||||||
|
dep_platform, arr_platform
|
||||||
|
from journeys
|
||||||
|
left join polylines on polylines.id = polyline_id
|
||||||
|
left join stations as dep_station on checkin_station_id = dep_station.eva
|
||||||
|
left join stations as arr_station on checkout_station_id = arr_station.eva
|
||||||
|
;
|
||||||
|
create view in_transit_str as select
|
||||||
|
user_id,
|
||||||
|
train_type, train_line, train_no, train_id,
|
||||||
|
extract(epoch from checkin_time) as checkin_ts,
|
||||||
|
extract(epoch from sched_departure) as sched_dep_ts,
|
||||||
|
extract(epoch from real_departure) as real_dep_ts,
|
||||||
|
checkin_station_id as dep_eva,
|
||||||
|
dep_station.ds100 as dep_ds100,
|
||||||
|
dep_station.name as dep_name,
|
||||||
|
dep_station.lat as dep_lat,
|
||||||
|
dep_station.lon as dep_lon,
|
||||||
|
extract(epoch from checkout_time) as checkout_ts,
|
||||||
|
extract(epoch from sched_arrival) as sched_arr_ts,
|
||||||
|
extract(epoch from real_arrival) as real_arr_ts,
|
||||||
|
checkout_station_id as arr_eva,
|
||||||
|
arr_station.ds100 as arr_ds100,
|
||||||
|
arr_station.name as arr_name,
|
||||||
|
arr_station.lat as arr_lat,
|
||||||
|
arr_station.lon as arr_lon,
|
||||||
|
polylines.polyline as polyline,
|
||||||
|
cancelled, route, messages, user_data,
|
||||||
|
dep_platform, arr_platform, data
|
||||||
|
from in_transit
|
||||||
|
left join polylines on polylines.id = polyline_id
|
||||||
|
left join stations as dep_station on checkin_station_id = dep_station.eva
|
||||||
|
left join stations as arr_station on checkout_station_id = arr_station.eva
|
||||||
|
;
|
||||||
|
update schema_version set version = 28;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
sub sync_stations {
|
sub sync_stations {
|
||||||
|
|
|
@ -473,7 +473,7 @@ sub get {
|
||||||
|
|
||||||
my @select
|
my @select
|
||||||
= (
|
= (
|
||||||
qw(journey_id train_type train_line train_no checkin_ts sched_dep_ts real_dep_ts dep_eva checkout_ts sched_arr_ts real_arr_ts arr_eva cancelled edited route messages user_data)
|
qw(journey_id train_type train_line train_no checkin_ts sched_dep_ts real_dep_ts dep_eva dep_ds100 dep_name dep_lat dep_lon checkout_ts sched_arr_ts real_arr_ts arr_eva arr_ds100 arr_name arr_lat arr_lon cancelled edited route messages user_data)
|
||||||
);
|
);
|
||||||
my %where = (
|
my %where = (
|
||||||
user_id => $uid,
|
user_id => $uid,
|
||||||
|
@ -524,10 +524,16 @@ sub get {
|
||||||
line => $entry->{train_line},
|
line => $entry->{train_line},
|
||||||
no => $entry->{train_no},
|
no => $entry->{train_no},
|
||||||
from_eva => $entry->{dep_eva},
|
from_eva => $entry->{dep_eva},
|
||||||
|
from_ds100 => $entry->{dep_ds100},
|
||||||
|
from_name => $entry->{dep_name},
|
||||||
|
from_latlon => [ $entry->{dep_lat}, $entry->{dep_lon} ],
|
||||||
checkin_ts => $entry->{checkin_ts},
|
checkin_ts => $entry->{checkin_ts},
|
||||||
sched_dep_ts => $entry->{sched_dep_ts},
|
sched_dep_ts => $entry->{sched_dep_ts},
|
||||||
rt_dep_ts => $entry->{real_dep_ts},
|
rt_dep_ts => $entry->{real_dep_ts},
|
||||||
to_eva => $entry->{arr_eva},
|
to_eva => $entry->{arr_eva},
|
||||||
|
to_ds100 => $entry->{arr_ds100},
|
||||||
|
to_name => $entry->{arr_name},
|
||||||
|
to_latlon => [ $entry->{arr_lat}, $entry->{arr_lon} ],
|
||||||
checkout_ts => $entry->{checkout_ts},
|
checkout_ts => $entry->{checkout_ts},
|
||||||
sched_arr_ts => $entry->{sched_arr_ts},
|
sched_arr_ts => $entry->{sched_arr_ts},
|
||||||
rt_arr_ts => $entry->{real_arr_ts},
|
rt_arr_ts => $entry->{real_arr_ts},
|
||||||
|
@ -541,15 +547,6 @@ sub get {
|
||||||
$ref->{polyline} = $entry->{polyline};
|
$ref->{polyline} = $entry->{polyline};
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( my $station = $self->{stations}->get_by_eva( $ref->{from_eva} ) ) {
|
|
||||||
$ref->{from_ds100} = $station->{ds100};
|
|
||||||
$ref->{from_name} = $station->{name};
|
|
||||||
}
|
|
||||||
if ( my $station = $self->{stations}->get_by_eva( $ref->{to_eva} ) ) {
|
|
||||||
$ref->{to_ds100} = $station->{ds100};
|
|
||||||
$ref->{to_name} = $station->{name};
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( $opt{with_datetime} ) {
|
if ( $opt{with_datetime} ) {
|
||||||
$ref->{checkin} = epoch_to_dt( $ref->{checkin_ts} );
|
$ref->{checkin} = epoch_to_dt( $ref->{checkin_ts} );
|
||||||
$ref->{sched_departure}
|
$ref->{sched_departure}
|
||||||
|
@ -935,8 +932,10 @@ sub get_travel_distance {
|
||||||
|
|
||||||
my $from = $journey->{from_name};
|
my $from = $journey->{from_name};
|
||||||
my $from_eva = $journey->{from_eva};
|
my $from_eva = $journey->{from_eva};
|
||||||
|
my $from_latlon = $journey->{from_latlon};
|
||||||
my $to = $journey->{to_name};
|
my $to = $journey->{to_name};
|
||||||
my $to_eva = $journey->{to_eva};
|
my $to_eva = $journey->{to_eva};
|
||||||
|
my $to_latlon = $journey->{to_latlon};
|
||||||
my $route_ref = $journey->{route};
|
my $route_ref = $journey->{route};
|
||||||
my $polyline_ref = $journey->{polyline};
|
my $polyline_ref = $journey->{polyline};
|
||||||
|
|
||||||
|
@ -979,32 +978,22 @@ sub get_travel_distance {
|
||||||
$prev_station = $station;
|
$prev_station = $station;
|
||||||
}
|
}
|
||||||
|
|
||||||
$prev_station = $self->{stations}->get_by_name( shift @route );
|
$prev_station = $self->{latlon_by_station}->{ shift @route };
|
||||||
if ( not $prev_station ) {
|
if ( not $prev_station ) {
|
||||||
return ( $distance_polyline, 0, 0 );
|
return ( $distance_polyline, 0, 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
my $from_station_beeline;
|
|
||||||
my $to_station_beeline;
|
|
||||||
|
|
||||||
for my $station_name (@route) {
|
for my $station_name (@route) {
|
||||||
if ( my $station = $self->{stations}->get_by_name($station_name) ) {
|
if ( my $station = $self->{latlon_by_station}->{$station_name} ) {
|
||||||
$from_station_beeline //= $prev_station;
|
|
||||||
$to_station_beeline = $station;
|
|
||||||
$distance_intermediate += $geo->distance_metal(
|
$distance_intermediate += $geo->distance_metal(
|
||||||
$prev_station->{lat}, $prev_station->{lon},
|
$prev_station->[0], $prev_station->[1],
|
||||||
$station->{lat}, $station->{lon}
|
$station->[0], $station->[1]
|
||||||
);
|
);
|
||||||
$prev_station = $station;
|
$prev_station = $station;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( $from_station_beeline and $to_station_beeline ) {
|
$distance_beeline = $geo->distance_metal( @{$from_latlon}, @{$to_latlon} );
|
||||||
$distance_beeline = $geo->distance_metal(
|
|
||||||
$from_station_beeline->{lat}, $from_station_beeline->{lon},
|
|
||||||
$to_station_beeline->{lat}, $to_station_beeline->{lon}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ( $distance_polyline, $distance_intermediate,
|
return ( $distance_polyline, $distance_intermediate,
|
||||||
$distance_beeline, $skipped );
|
$distance_beeline, $skipped );
|
||||||
|
|
Loading…
Reference in a new issue