Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Address Minor Issues Associated with ARC Update to Develop Branch #342

Merged
merged 27 commits into from
Sep 16, 2020

Conversation

danielsclint
Copy link

Adds three components and cleans up one error in the test data.

  1. try...except blocks to help track down which file is causing the error. Some models have underlying connections to other models (e.g., mode_choice), so its not always apparent which model the error is originating. This adds a simple output to more clearly delineate which user input file is causing problems.

image

  1. Move up coefficient processing in vectorize_tour_scheduling.py to ensure the coefficients are available to the preprocessor (Coefficients by Segment Necessary for Preprocessor #333)

  2. Point joint_tour_destination.py to use the joint_tour_destination.yaml file. (Joint Tour Destination Changed to Use Non-Mandatory Destination Choice Model Settings #335)

  3. Remove duplicate coefficient specification in non_mandatory_tour_destination_coeffs.csv.

Review Criteria Responses

  1. Does it contain all the required elements, including a runnable example, documentation, and tests?
    This code doesn't change the examples or documentation.

  2. Does it implement good methods (i.e. is it consistent with good practices in travel modeling)?
    Yes. Better debugging of user files.

  3. Are the runtimes reasonable and does it provide documentation justifying this claim?
    This change has no material impact on runtimes.

  4. Does it include non-Python code, such as C/C++? If so, does it compile on any OS and are compilation instructions included?
    No. This is a Python-only change.

  5. Is it licensed with the ActivitySim license that allows the code to be freely distributed and modified and includes attribution so that the ‘provenance’ of the code can be tracked? Does it include an official release of ownership from the funding agency if applicable?
    This work was done under contract to ARC, and, presumably, ARC is providing the changes without any additional licensing beyond the existing ActivitySim licensing.

  6. Does it appropriately interact with the data pipeline (i.e. it doesn't create new ways of managing data)?
    This change does not impact the data pipeline.

  7. Does it include regression tests to enable checking that consistent results will be returned when updates are made to the framework?
    No regression testing has been done.

  8. Does it include sufficient test coverage and test data for existing and proposed features?
    No

  9. Any other comments or suggestions for improving the developer experience?
    N/A

bstabler and others added 7 commits September 3, 2020 18:08
* update docs, drop scripts no longer needed, include example files in package

* Pandas 1.0 fixes

* Location and mode choice logsums (ActivitySim#298)

* Tncs (ActivitySim#14)

* write trip matrices (ActivitySim#311)

* small fixes for semcog deployment (ActivitySim#319)

* improved validation diagnostics in trip_purpose and various windows-related int32/int64 conversions

* fix bug in handling of no viable trips case in choose_trip_destination

* major work on phase 5 (ActivitySim#325)

* estimation through atwork_subtour_mode_choice

* Tnc updates and notebooks (ActivitySim#18)

* move other resources into folder since examples now part of package as well

* add example zone shapefile

* estimation notebooks for larch (ActivitySim#19)

* multiprocessing related logging and error checking

* trip_destination handle all trips fail

* skim caching with numpy memmap to speed skim loading

* better chunking in vectorize_tour_scheduling

* Cli (ActivitySim#22)

* use activitysim_resources

Fixed auto sufficiency conditions in tour_mode_choice.csv. (Issue ActivitySim#324)

* correct write trip matrices sampling expansion and add vehicle occupancy to the expression file

* additional updates for estimation integration  (ActivitySim#328)

* improve LICENSE (ActivitySim#30)

* correct univ coeff template lookup (ActivitySim#28)

Co-authored-by: Clint Daniels <[email protected]>
Co-authored-by: Blake <[email protected]>
Co-authored-by: Blake Rosenthal <[email protected]>
Co-authored-by: Jeff Doyle <[email protected]>
Co-authored-by: Jeffrey Doyle <[email protected]>
Co-authored-by: Jeffrey Newman <[email protected]>
@coveralls
Copy link

coveralls commented Sep 9, 2020

Coverage Status

Coverage decreased (-0.04%) to 81.05% when pulling e06f5f0 on danielsclint:hf_bugs into 205c391 on ActivitySim:develop.

@bstabler
Copy link
Contributor

thanks @danielsclint - these contributions look straightforward. Can you update your branch since we pulled in a bunch of work for version 0.9.5?

@danielsclint
Copy link
Author

@bstabler: Your killing me with these little commits... 😂 Shoot me an email when you are stable, and I'll rebase.

@bstabler
Copy link
Contributor

bstabler commented Sep 10, 2020

I'm done @danielsclint, sorry about that. I needed to correct a couple outdated weblinks in the docs with the latest release.

@toliwaga toliwaga self-assigned this Sep 16, 2020
@toliwaga
Copy link
Contributor

As we discussed, this all looks fine to me.

Copy link
Contributor

@toliwaga toliwaga left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good.

@toliwaga toliwaga merged commit 8b9df09 into ActivitySim:develop Sep 16, 2020
@danielsclint danielsclint deleted the hf_bugs branch October 23, 2020 04:10
danielsclint pushed a commit to danielsclint/activitysim that referenced this pull request Dec 15, 2020
…tivitySim#342)

* publish v0.9.5 (ActivitySim#340)

* update docs, drop scripts no longer needed, include example files in package

* Pandas 1.0 fixes

* Location and mode choice logsums (ActivitySim#298)

* Tncs (ActivitySim#14)

* write trip matrices (ActivitySim#311)

* small fixes for semcog deployment (ActivitySim#319)

* improved validation diagnostics in trip_purpose and various windows-related int32/int64 conversions

* fix bug in handling of no viable trips case in choose_trip_destination

* major work on phase 5 (ActivitySim#325)

* estimation through atwork_subtour_mode_choice

* Tnc updates and notebooks (ActivitySim#18)

* move other resources into folder since examples now part of package as well

* add example zone shapefile

* estimation notebooks for larch (ActivitySim#19)

* multiprocessing related logging and error checking

* trip_destination handle all trips fail

* skim caching with numpy memmap to speed skim loading

* better chunking in vectorize_tour_scheduling

* Cli (ActivitySim#22)

* use activitysim_resources

Fixed auto sufficiency conditions in tour_mode_choice.csv. (Issue ActivitySim#324)

* correct write trip matrices sampling expansion and add vehicle occupancy to the expression file

* additional updates for estimation integration  (ActivitySim#328)

* improve LICENSE (ActivitySim#30)

* correct univ coeff template lookup (ActivitySim#28)

Co-authored-by: Clint Daniels <[email protected]>
Co-authored-by: Blake <[email protected]>
Co-authored-by: Blake Rosenthal <[email protected]>
Co-authored-by: Jeff Doyle <[email protected]>
Co-authored-by: Jeffrey Doyle <[email protected]>
Co-authored-by: Jeffrey Newman <[email protected]>

* Remove duplicate coefficient.

* move coefficient processing up

* Update joint_tour_destination.py

* Fix reference to joint tour destination.yaml

* Error check for COEFFICIENT files

* Add person_id to joint choosers.

* move notebooks to examples folder so they are installed and update docs as a result (ActivitySim#343)

* publish (ActivitySim#344)

* move notebooks to examples folder so they are installed and update docs as a result (ActivitySim#343)

* correct doc links

* Remove duplicate coefficient.

* move coefficient processing up

* Update joint_tour_destination.py

* Fix reference to joint tour destination.yaml

* Error check for COEFFICIENT files

* Add person_id to joint choosers.

* Remove duplicate coefficient.

* move coefficient processing up

* Update joint_tour_destination.py

* Fix reference to joint tour destination.yaml

* Error check for COEFFICIENT files

* Add person_id to joint choosers.

Co-authored-by: Ben Stabler <[email protected]>
Co-authored-by: Blake <[email protected]>
Co-authored-by: Blake Rosenthal <[email protected]>
Co-authored-by: Jeff Doyle <[email protected]>
Co-authored-by: Jeffrey Doyle <[email protected]>
Co-authored-by: Jeffrey Newman <[email protected]>
Co-authored-by: bstabler <[email protected]>
bstabler added a commit that referenced this pull request Jan 12, 2021
* Provide more flexibility for defining mandatory schedule specifications.

* provide more flexibility for time periods.

* Improve consistency in slicing and fix code syntax issues.

* Consistency and code syntax.

* code syntax.

* code syntax fixes.

* syntax fix.

* Add necessary change to test script settings.

* Modify relevant section of the settings.yml for tests and examples.

* restore 'hours' as deprecated for backwards compatibility.

* Add default value for period_minutes for backwards compatibilitiy.

* create develop branch so we can merge features here before merging (releasing) to master

* provide more flexibility for time periods.

* Improve consistency in slicing and fix code syntax issues.

* Consistency and code syntax.

* code syntax fixes.

* Modify relevant section of the settings.yml for tests and examples.

* restore 'hours' as deprecated for backwards compatibility.

* Add default value for period_minutes for backwards compatibilitiy.

* Fix overflows

* Complete testing of the flexible time periods.

* pep8

* test some floats too.

* pep8

* start with csvs and write hdf5 outputs if desired  (#290)

* add h5_store option to write_tables

* keep csv files as the default

* read input tables from CSV

* update docs, drop scripts no longer needed, include example files in package

* formatting

Co-authored-by: Blake <[email protected]>

* Update travis.yml

* Pandas 1.0 fixes

* Location and mode choice logsums (#298)

* optional logsums for location_choice and tour destination models

* mode choice logsums for trous and trips

* trip DEST_CHOICE_SAMPLE_TABLE_NAME

* update docs for writing logsums and also a couple small development page updates

* fix small py2 py 3 compatibility issue

* py2 py3 compatibility

Co-authored-by: Blake <[email protected]>
Co-authored-by: Jeff Doyle <[email protected]>

* Deprecate Py2 and add CLI

* Tncs (#14)

* add tncs

* lognormal_for_df broadcasts duplicate indexes

* lognormal_for_df broadcasts duplicate indexes code

* correct lognormal calculations and add functions to calculation lognormal location and scale

* clean-up tnc wait time expressions

* set taxi, tnc wait time standard deviations to zero until we have better data

* add scaled option to random.lognormal_for_df

* add mobility-as-a-service modes to docs

* updated tnc mode constants

* rename maas to ridehail

Co-authored-by: Jeff Doyle <[email protected]>
Co-authored-by: Blake Rosenthal <[email protected]>

* write trip matrices (#311)

require newer pandas

add ability to save trips table to pipeline and begin to finish example

all time periods

fix trip scheduling bug

add support for odt skims as well

Co-authored-by: Ben Stabler <[email protected]>

Co-authored-by: Blake Rosenthal <[email protected]>

* small fixes for semcog deployment (#319)

* improved validation diagnostics in trip_purpose and various windows-related int32/int64 conversions

* pycodestyle

* deprecations in test code

* fix bug in handling of no viable trips case in choose_trip_destination

* add trace folder to example_mtc output folder

Co-authored-by: Jeffrey Doyle <[email protected]>
Co-authored-by: Jeff Doyle <[email protected]>

* major work on phase 5 (#325)

* estimation through atwork_subtour_mode_choice

* Tnc updates and notebooks (#18)

* move other resources into folder since examples now part of package as well

* add shapefile

* clean up folder setup

* estimation notebooks for larch (#19)

* multiprocessing related logging and error checking

* trip_destination handle all trips fail

* skim caching with numpy memmap to speed skim loading

* better chunking in vectorize_tour_scheduling

* Cli (#22)

* use activitysim_resources

Fixed auto sufficiency conditions in tour_mode_choice.csv. (Issue #324)

* increment to version 0.9.5

* correct write trip matrices sampling expansion and add vehicle occupancy to the expression file

* updates to documentation for phase 5 work except multiple zone systems

* additional updates for estimation integration  (#328)

* estimation integration updates #327
* drop module no longer needed

* update license, fix univ coeff bug, update estimation example (#339)

* improve example setup for specifying input tables (#27)
* improve LICENSE (#30)
* correct univ coeff template lookup (#28)

* add license to package (#341)

* move notebooks to examples folder so they are installed and update docs as a result (#343)

* correct doc links

* Address Minor Issues Associated with ARC Update to Develop Branch (#342)

* publish v0.9.5 (#340)

* update docs, drop scripts no longer needed, include example files in package

* Pandas 1.0 fixes

* Location and mode choice logsums (#298)

* Tncs (#14)

* write trip matrices (#311)

* small fixes for semcog deployment (#319)

* improved validation diagnostics in trip_purpose and various windows-related int32/int64 conversions

* fix bug in handling of no viable trips case in choose_trip_destination

* major work on phase 5 (#325)

* estimation through atwork_subtour_mode_choice

* Tnc updates and notebooks (#18)

* move other resources into folder since examples now part of package as well

* add example zone shapefile

* estimation notebooks for larch (#19)

* multiprocessing related logging and error checking

* trip_destination handle all trips fail

* skim caching with numpy memmap to speed skim loading

* better chunking in vectorize_tour_scheduling

* Cli (#22)

* use activitysim_resources

Fixed auto sufficiency conditions in tour_mode_choice.csv. (Issue #324)

* correct write trip matrices sampling expansion and add vehicle occupancy to the expression file

* additional updates for estimation integration  (#328)

* improve LICENSE (#30)

* correct univ coeff template lookup (#28)

Co-authored-by: Clint Daniels <[email protected]>
Co-authored-by: Blake <[email protected]>
Co-authored-by: Blake Rosenthal <[email protected]>
Co-authored-by: Jeff Doyle <[email protected]>
Co-authored-by: Jeffrey Doyle <[email protected]>
Co-authored-by: Jeffrey Newman <[email protected]>

* Remove duplicate coefficient.

* move coefficient processing up

* Update joint_tour_destination.py

* Fix reference to joint tour destination.yaml

* Error check for COEFFICIENT files

* Add person_id to joint choosers.

* move notebooks to examples folder so they are installed and update docs as a result (#343)

* publish (#344)

* move notebooks to examples folder so they are installed and update docs as a result (#343)

* correct doc links

* Remove duplicate coefficient.

* move coefficient processing up

* Update joint_tour_destination.py

* Fix reference to joint tour destination.yaml

* Error check for COEFFICIENT files

* Add person_id to joint choosers.

* Remove duplicate coefficient.

* move coefficient processing up

* Update joint_tour_destination.py

* Fix reference to joint tour destination.yaml

* Error check for COEFFICIENT files

* Add person_id to joint choosers.

Co-authored-by: Ben Stabler <[email protected]>
Co-authored-by: Blake <[email protected]>
Co-authored-by: Blake Rosenthal <[email protected]>
Co-authored-by: Jeff Doyle <[email protected]>
Co-authored-by: Jeffrey Doyle <[email protected]>
Co-authored-by: Jeffrey Newman <[email protected]>
Co-authored-by: bstabler <[email protected]>

* fix #288 chunk joint_touyr_participation by chunk_id and update tests to catch such errors

* gitignore trivia

* Support for Multiple Zone Systems and Transit Virtual Path Building (#362)

* TransitVirtualPathBuilder first cut - get_tvpb_logsum computes logsums on demand

* tour_mode_choice logsums for 3-zone working for school and workplace location

* z3 running all models, but with hacked trip_mode_choice (no coefficient templates)

* z3 running all models

* passing tests

* pcodestyle passes

* refactored test teardown

* tvpb tracing

* tvpb tracing roughout

* build multizone test data before running test

* read_settings_file support include_settings

* read_settings_file support include_settings

* move constants to configs yaml and expressions from abm.util to core

* tvpb estimate_chunk_overhead

* adaptive chunking

* fixed bug in trip scheduling when no trips in leg after iteration

* 3 zone tap_tap uniquify

* tvpb TableCache

* tvpb TableCache - all fiiels

* 3 zone with feather cache

* tidy up notes around creating the marin example

* memmap skims

* memmap skims

* correct drive transit cost expression for miles/feet.  Still need to add some additional missing expressions now that everything appears to be working correctly.

* skim docstrings

* disable 3 zone tap_tap caching for traced taps

* initialize_los

* 3 zone mp plumbing untested

* THREE_ZONE tvpb multiprocessing tests and fixes

* THREE_ZONE tvpb multiprocessing tests and fixes

* reanme core tvpb and cache modules

* reanme core tvpb and cache modules

* util.iprod alias for np.prod with dtype int64

* THREE_ZONE cache initialization bug bixes

* multizone bug fixes

* bugs

* multiprocessing mjultizone tweaks

* tvpb cacha\e as array

* complain if apporting with more process than slice rows

* complain if apporting with more process than slice rows

* chunk initialize_tvpb

* shorter trace file names because windows

* refactor pathbuilder sans DYNAMIC

* fix tour_scheduling_calc_row_size

* fix multiprocess resume across mp step bug

* pycodestyle

* minor chunk cleanup

* allow MemMapSkimFactory multiprocessing

* consolidate mtc and multizone configs

* commit updated marin example config files

* some more marin example config updates

* add validation summaries script

* some additional marin example updates

* update example skim time period settings to align with tm1 (#360)

* update example settings to align with tm1

* correct home_is_rural coding since tm1 was incorrect

* corrected skim time periods go in network_los.yaml now

* travis depends on these scripts for testing

* improve logging and increase travis timeout

* #359 (#364)

* updates for CDAP person type mapping

* allow duplicate time labels

* fix a copy small items for #359

* test updates

* pycodestyle

* 3 zone test fix

Co-authored-by: Clint Daniels <[email protected]>

* longer travis timeout and avoid file permissions between tests related to caching

* test-travis

* ls fix

* add timeout

* fix path

* put in both locations for now

* reduce household sample sizes for tests to avoid travis timeout

* not sure what's taking so long with the second and third tests.  It runs in 40 minutes with py 3.7 on my computer as well

* linux file paths

* cli test depends on py 3.7+

* add coveralls back

* test new architecture

* try build matrix

* setup environments

* correct matrix expansion

* correct duplicate key

* correct key

* correct env usage

* no need to specify architecture

* update inject settings for tests

* updated examples to use activitysim resources repo

* rename folder

* update survey test files so all example_manifest.yaml examples now running

* updated notebooks, default settings for examples, and updated rst files

* fix a couple typos

* add comments to travis script

* ARC Updates (#365)

Add parking_location_choice, trip_departure_choice, and trip_scheduling_choice models.

* add example_mtc_arc_extensions so arc extensions can be run and tested

* small doc update

* fix arc extensions example

Co-authored-by: Clint Daniels <[email protected]>
Co-authored-by: Blake <[email protected]>
Co-authored-by: Blake Rosenthal <[email protected]>
Co-authored-by: Jeff Doyle <[email protected]>
Co-authored-by: Jeffrey Doyle <[email protected]>
Co-authored-by: Jeffrey Newman <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants