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

fix: simplifies, fixes and documents left and right shift of Interval #172

Merged
merged 2 commits into from
Feb 26, 2024

Conversation

rolanddenis
Copy link
Contributor

  • I have installed pre-commit locally and use it to validate my commits.
  • The PR title follows the conventional commits convention.
    Available tags: 'build', 'chore', 'ci', 'docs', 'feat', 'fix', 'perf', 'refactor', 'revert', 'style', 'test'
  • This new PR is documented.
  • This new PR is tested.

Description

There was some issues with current implementation of right shift of an Interval:

  • it was complicated with many checks,
  • the result was wrong for right shift of 0 and 2 steps (and probably more).

This PR adds a more thorough test of Interval's left and right shift and implements a new formula for the right shift that is consistent with previous behaviour for unitary step and fixes the others steps.

The formula is explained and justified in the documentation.

How has this been tested?

Thorough test in test_interval.cpp.

Code of Conduct

By submitting this PR, you agree to follow our Code of Conduct

  • I agree to follow this project's Code of Conduct

Sorry, something went wrong.

It shows issues with right shift of 0 and 2 steps (and probably above).
The right shift algorithm can be simplified using a one line code, that
is also more robust (for shift other than 1).
The formula is explained and justified in the documentation of Interval.
@gouarin gouarin merged commit db8ce1c into hpc-maths:master Feb 26, 2024
16 checks passed
@rolanddenis rolanddenis deleted the fix_interval_shift branch February 26, 2024 13:05
gouarin pushed a commit that referenced this pull request Feb 29, 2024

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
🤖 I have created a release *beep* *boop*
---


##
[0.10.0](v0.9.0...v0.10.0)
(2024-02-29)


### Features

* add dim in field_operator_base
([#168](#168))
([d74b6ca](d74b6ca))
* additional initial value parameter to make_field
([#162](#162))
([3536eac](3536eac))
* Boundary conditions with configurable stencil
([#167](#167))
([e59c2a4](e59c2a4))
* collapsable flux value in non-linear flux-based schemes
([#165](#165))
([bca0474](bca0474))
* const field in FV operator lambdas
([#164](#164))
([7a78d2b](7a78d2b))
* local newton solvers
([#153](#153))
([699468e](699468e))
* Non-conservative fluxes
([#161](#161))
([61d1cfd](61d1cfd))
* Parallelization using MPI
([#28](#28))
([a411c76](a411c76))
* use xexpression for get_interval, get_index and get_cell
([#170](#170))
([9391d2d](9391d2d))
* WENO5 scheme ([#166](#166))
([55fe777](55fe777))


### Bug Fixes

* cell array instead of cell xtensor for the stencil of non-linear
cell-based schemes
([#156](#156))
([2487af3](2487af3))
* Fix flux-based schemes with unsymmetric stencil
([#157](#157))
([697cca6](697cca6))
* Fix operators for time integration
([#154](#154))
([7993525](7993525))
* fixing (almost) all warnings triggered when compiling tests & demos
([#163](#163))
([246ebcb](246ebcb))
* right shift on interval
([#169](#169))
([67f84e1](67f84e1))
* simplifies, fixes and documents left and right shift of Interval
([#172](#172))
([db8ce1c](db8ce1c))

---
This PR was generated with [Release
Please](https://github.com/googleapis/release-please). See
[documentation](https://github.com/googleapis/release-please#release-please).

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
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.

None yet

2 participants