-
-
Notifications
You must be signed in to change notification settings - Fork 595
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
[RFC]: refactor @stdlib/complex
into sub-namespaces
#2260
Comments
This should be fine and seems sensible. We will need to ensure to deprecate the various packages already published to |
@Planeshifter Sorry, I have already forgotten. Can our existing automation work with conventional commits? Or do we need to include additional meta information in the commit messages? |
@kgryte Currently, we have https://github.com/stdlib-js/metadata-action to process YAML blocks in commit messages, which could be used to build out a method to deprecate packages via the commit messages. We don't have any existing automation for deprecations where the conventional commit |
This commit copies the constructor implementation for `complex/float32` to a new package for the purposes of eventually creating a complex sub-namespace for single-precision complex numbers. Ref: #2260
This commit copies the constructor implementation for `complex/float64` to a new package for the purposes of eventually creating a complex sub-namespace for double-precision complex numbers. Ref: #2260
This commit copies `@stdlib/complex/reviver-float32` to a new package within the `complex/float32` sub-namespace. Ref: #2260
This commit removes `@stdlib/complex/reviver-float32` in favor of `@stdlib/complex/float32/reviver`. BREAKING CHANGE: remove `complex/reviver-float32` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/reviver` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/reviver-float64` in favor of `@stdlib/complex/float64/reviver`. BREAKING CHANGE: remove `complex/reviver-float64` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/reviver` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/parse-float32` in favor of `@stdlib/complex/float32/parse`. BREAKING CHANGE: remove `complex/parse-float32` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/parse` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/parse-float64` in favor of `@stdlib/complex/float64/parse`. BREAKING CHANGE: remove `complex/parse-float64` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/parse` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/base/assert/is-equal` in favor of `@stdlib/complex/float64/base/assert/is-equal`. BREAKING CHANGE: remove `complex/base/assert/is-equal` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/base/assert/is-equal` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/base/assert/is-same-valuef` in favor of `@stdlib/complex/float32/base/assert/is-same-value`. BREAKING CHANGE: remove `complex/base/assert/is-same-valuef` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/base/assert/is-same-value` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/base/assert/is-same-value-zerof` in favor of `@stdlib/complex/float32/base/assert/is-same-value`. BREAKING CHANGE: remove `complex/base/assert/is-same-value-zerof` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/base/assert/is-same-value` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/base/assert/is-same-value-zero` in favor of `@stdlib/complex/float64/base/assert/is-same-value-zero`. BREAKING CHANGE: remove `complex/base/assert/is-same-value-zero` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/base/assert/is-same-value-zero` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/base/assert/is-same-value` in favor of `@stdlib/complex/float64/base/assert/is-same-value`. BREAKING CHANGE: remove `complex/base/assert/is-same-value` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/base/assert/is-same-value` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/base/assert/is-equalf` in favor of `@stdlib/complex/float32/base/assert/is-equal`. BREAKING CHANGE: remove `complex/base/assert/is-equalf` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/base/assert/is-equal` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/reim` in favor of `@stdlib/complex/float64/reim`. BREAKING CHANGE: remove `complex/reim` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/reim` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/imagf` in favor of `@stdlib/complex/float32/imag`. BREAKING CHANGE: remove `complex/imagf` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/imag` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/imag` in favor of `@stdlib/complex/float64/imag`. BREAKING CHANGE: remove `complex/imag` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/imag` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/complex/realf` in favor of `@stdlib/complex/float32/real`. BREAKING CHANGE: remove `complex/realf` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/real` which provides the same API and implementation. Ref: #2260
List of deprecated packages:
|
This commit removes `@stdlib/complex/real` in favor of `@stdlib/complex/float64/real`. BREAKING CHANGE: remove `complex/real` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/real` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/math/base/ops/caddf` in favor of `@stdlib/complex/float32/base/add`. BREAKING CHANGE: remove `math/base/ops/caddf` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/base/add` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/math/base/ops/cadd` in favor of `@stdlib/complex/float64/base/add`. BREAKING CHANGE: remove `math/base/ops/cadd` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/base/add` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/math/base/ops/cmulf` in favor of `@stdlib/complex/float32/base/mul`. BREAKING CHANGE: remove `math/base/ops/cmulf` To migrate, users should update their require/import paths to use `@stdlib/complex/float32/base/mul` which provides the same API and implementation. Ref: #2260
This commit removes `@stdlib/math/base/ops/cmul` in favor of `@stdlib/complex/float64/base/mul`. BREAKING CHANGE: remove `math/base/ops/cmul` To migrate, users should update their require/import paths to use `@stdlib/complex/float64/base/mul` which provides the same API and implementation. Ref: #2260
This commit reflects recent changes in the complex number namespace. Various exports have moved to sub-namespaces or have been renamed. BREAKING CHANGE: update namespace declarations To migrate, users should see the guidance found in the relevant commits for namespace refactoring. See issue #2260. PR-URL: #2628 Ref: #2260 Co-authored-by: Athan Reines <kgryte@gmail.com> Reviewed-by: Athan Reines <kgryte@gmail.com> Signed-off-by: stdlib-bot <82920195+stdlib-bot@users.noreply.github.com>
This commit reflects recent changes in the complex number namespace. Various exports have moved to sub-namespaces or have been renamed. BREAKING CHANGE: update namespace declarations To migrate, users should see the guidance found in the relevant commits for namespace refactoring. See issue stdlib-js#2260. PR-URL: stdlib-js#2628 Ref: stdlib-js#2260 Co-authored-by: Athan Reines <kgryte@gmail.com> Reviewed-by: Athan Reines <kgryte@gmail.com> Signed-off-by: stdlib-bot <82920195+stdlib-bot@users.noreply.github.com>
Description
This RFC proposes refactoring the
@stdlib/complex
namespace into separate sub-namespaces forfloat32
andfloat64
.Currently, the
@stdlib/complex
is a flat(ish) namespace, containing top-level packages which are tailored to specific data types.For example, for double-precision complex floating-point numbers, we have
@stdlib/complex/conj
@stdlib/complex/float64
@stdlib/complex/imag
@stdlib/complex/parse-float64
@stdlib/complex/real
@stdlib/complex/reim
@stdlib/complex/reviver-float64
Similarly, we have equivalent packages for single-precision complex floating-point numbers.
Accordingly, in order to distinguish double- and single-precision variants, we resort to suffixes (e.g.,
*f
or-floatXX
). This has worked fine and mirrors@stdlib/math/base/special/*
.However, this structure departs from the structure of
@stdlib/number/*
, where number dtypes and their associated functionality is broken down into sub-namespaces. This has the advantage in that we can avoid suffix name pollution and have similarly named packages across each of the different numeric data types. This will be especially useful when we add base operations (e.g.,@stdlib/number/int32/base/add
), where for many numeric dtypes (e.g.,int8
,uint8
, etc), we don't have suffix conventions (i.e., we have noint8
equivalent off
and are unlikely to ever have such an equivalent).Accordingly, what this RFC proposes is a refactoring of the
@stdlib/complex/*
namespace to match the@stdlib/number/*
namespace. E.g.,@stdlib/complex/float64/ctor
@stdlib/complex/float64/real
@stdlib/complex/float64/imag
@stdlib/complex/float64/add
@stdlib/complex/float32/ctor
@stdlib/complex/float32/real
(no suffix!)@stdlib/complex/float32/imag
(no suffix!)@stdlib/complex/float32/add
(no suffix!)@stdlib/complex/ctors
@stdlib/complex/cmplx
@stdlib/complex/reviver
where we keep the APIs which operate on or return either complex dtype at the top-level.
A consequence of this refactoring is that it should help make things a bit cleaner in the top-level
@stdlib/complex
namespace when adding support for half-precision complex floating-point numbers (as needed based on future inclusion ofFloat16Array
in ECMAScript) and allow us to avoid needing to use a new suffix to differentiate the associated APIs.As it is, that
@stdlib/number
and@stdlib/complex
are organized differently has been a source of friction for me and having organizational parity seems more intuitive.Related Issues
No.
Questions
No.
Other
The migration path would be as follows:
@stdlib/complex/float32
and@stdlib/complex/float64
to@stdlib/complex/float32/ctor
and@stdlib/complex/float64/ctor
, respectively.require
paths using those packages.require
paths using the dtype-specific complex packages.@stdlib/complex
namespace.cc @Planeshifter
Checklist
RFC:
.The text was updated successfully, but these errors were encountered: