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

[Do not Merge] Remove implicit pinvs of vectors #40758

Closed
wants to merge 3 commits into from

Conversation

antoine-levitt
Copy link
Contributor

Fix JuliaLang/LinearAlgebra.jl#1165

This is breaking so should not be merged yet, I'm putting it up as suggested by @ViralBShah so PkgEval can be run to see if anybody actually uses this.

@DilumAluthge DilumAluthge added the breaking This change will break code label May 9, 2021
@ViralBShah ViralBShah changed the title Remove implicit pinvs of vectors [Do not Merge] Remove implicit pinvs of vectors May 9, 2021
@ViralBShah ViralBShah marked this pull request as draft May 9, 2021 15:13
@ViralBShah
Copy link
Member

@nanosoldier runtests(ALL, vs = ":master")

@ViralBShah
Copy link
Member

ViralBShah commented May 9, 2021

The base tests will need fixing to be in line and all green with this before we should run pkgeval. I kicked it off a bit too soon.

@antoine-levitt
Copy link
Contributor Author

Should be good now!

@ViralBShah
Copy link
Member

Does marking this PR as draft prevent a nanosoldier run from triggering?

@nanosoldier
Copy link
Collaborator

Something went wrong when running your job:

NanosoldierError: failed to run tests: AWSException: XAmzContentSHA256Mismatch -- The provided 'x-amz-content-sha256' header does not match what was computed.
HTTP.ExceptionRequest.StatusError(400, "PUT", "/julialang-reports/nanosoldier/pkgeval/by_hash/881c0ed_vs_27d3931/OptimKit.1.7.0-DEV-e81314476e.log?x-amz-acl=public-read", HTTP.Messages.Response:
"""
HTTP/1.1 400 Bad Request
x-amz-request-id: 2YY666KAG818P6K6
x-amz-id-2: 3OSuKP8bvnenAYeulnFb84IpR5FX37IFCvrhoa1KGNi8Bems//FFacUOasPaHL2o3oW8RLUnKZY=
Content-Type: application/xml
Transfer-Encoding: chunked
Date: Sun, 09 May 2021 20:54:07 GMT
Server: AmazonS3
Connection: close

<?xml version="1.0" encoding="UTF-8"?>
<Error><Code>XAmzContentSHA256Mismatch</Code><Message>The provided 'x-amz-content-sha256' header does not match what was computed.</Message><ClientComputedContentSHA256>a46d6b98a0005193b412e8c48b9626c652c7554a7fa8cf29c09a58c4a7920cd6</ClientComputedContentSHA256><S3ComputedContentSHA256>6671bb835e70b4055bbb18e58c414af4fb9b677a8b6848fbef1bd08afaf01b26</S3ComputedContentSHA256><RequestId>2YY666KAG818P6K6</RequestId><HostId>3OSuKP8bvnenAYeulnFb84IpR5FX37IFCvrhoa1KGNi8Bems//FFacUOasPaHL2o3oW8RLUnKZY=</HostId></Error>""")

Logs and partial data can be found here
cc @maleadt

@ViralBShah
Copy link
Member

@nanosoldier runtests(ALL, vs = ":master")

@ViralBShah ViralBShah added the linear algebra Linear algebra label May 10, 2021
@ViralBShah ViralBShah added this to the 2.0 milestone May 10, 2021
@nanosoldier
Copy link
Collaborator

Your package evaluation job has completed - possible new issues were detected. A full report can be found here. cc @maleadt

@antoine-levitt
Copy link
Contributor Author

The following are real:
DiffEqDevTools
DomainSets
Indicators
MRIReco
QuantEcon
QuantumOpticsBase
RecordedArrays

Will take a look at some point to see which of these are overzealous testing vs real usage

@antoine-levitt
Copy link
Contributor Author

antoine-levitt commented May 11, 2021

I had some preliminary look at this. DiffEqDevTools and QuantumOpticsBase look very much like bugs. Eg DiffEqDevTools has

abstols = 1. /10 .^(3:10)
reltols = 1 ./10 .^(3:10)

which is a pretty strong argument for this PR :-) Will open issues there.

RecordedArrays and DomainSets look like overzealous testing. I could not easily determine Indicators, MRIReco and QuantEcon, I'll try to investigate locally. Also this PR results in some infinite loops, we should probably just restrict to AbstractMatrix here:

/(u::AdjointAbsVec, A::Transpose{<:Any,<:AbstractMatrix}) = adjoint(conj(A.parent) \ u.parent) # technically should be adjoint(copy(adjoint(copy(A))) \ u.parent)
/(u::TransposeAbsVec, A::Adjoint{<:Any,<:AbstractMatrix}) = transpose(conj(A.parent) \ u.parent) # technically should be transpose(copy(transpose(copy(A))) \ u.parent)

@ViralBShah
Copy link
Member

@ChrisRackauckas Note the DiffeqDevTools issue here.

@antoine-levitt
Copy link
Contributor Author

antoine-levitt commented May 11, 2021

Indicators, MRIReco (via NFFT) and QuantEcon are legitimate: they do x \ y to fit y = a*x in least squares. Under this PR x would have to be converted to a matrix before doing that. We could plausibly kill something / vector but not vector \ something. That would be inconsistent, but it would catch most errors, while keeping the full functionality of backslashes (backslashes usually imply tricky linear algebra intent, unlike forward slashes)

@antoine-levitt
Copy link
Contributor Author

antoine-levitt commented May 11, 2021

So summing up, seven failures: one overzealous testing, two using number / vector by error, and four using vector \ vector on purposes for linear regression. That supports removing number / vector at least.

@simeonschaub simeonschaub added forget me not PRs that one wants to make sure aren't forgotten linalg triage labels Nov 1, 2021
@simeonschaub
Copy link
Member

We probably should make a definite decision here. I have marked it for linalg triage now, but I'm not sure it ever convened, so we might just want to regularly triage this?

@ViralBShah
Copy link
Member

Should probably rebase to master and rerun pkgeval.

@antoine-levitt
Copy link
Contributor Author

antoine-levitt commented Nov 2, 2021

Done. Let's see if I can summon?
@nanosoldier runtests(ALL, vs = ":master")
edit: nope, doesn't seem like I can, can someone with permissions do it?

@maleadt
Copy link
Member

maleadt commented Nov 2, 2021

@nanosoldier runtests(ALL, vs = ":master")

@nanosoldier
Copy link
Collaborator

Your package evaluation job has completed - possible new issues were detected. A full report can be found here.

@antoine-levitt
Copy link
Contributor Author

Nothing new here.

To sum up, there's two methods here: 1 scalar / vector 2 vector / vector, which through fallbacks provides vector \ vector.

1 is not used in any package as far as I can see, and I have trouble seeing a use for it. It's very dangerous because of the possible confusion with scalar ./ vector (which is much more used): it also produces an array and so has the potential for silent corruption (as was found in several packages in the previous pkgeval run). It is the worst offender and should ideally be removed ASAP, if possible.

Regarding 2, vector \ vector is legitimately used in packages for fitting one vector to another, which is nice and useful. vector / vector is much less useful. My guess is that this is because x \ y is overdetermined and simply defined as the scalar a that minimizes ||x-a y||, whereas x / y is undetermined and is defined as the matrix that minimizes ||x - A y|| and has minimal norm.

I think we should definitely do 1 ASAP. Regarding 2, we could leave it as is, remove only vector / vector, or also remove vector \ vector. I would be in favor of removing both of them. The rule would then be that vectors are never pseudo-inverted implicitly and have to be converted to matrices. The deprecation would be from x / y to x / hcat(y) and x \ y to hcat(x) \ y.

Removing either is technically breaking, so I'm not sure how eligible that is in the 1.x timeline. We should not remove vector \ vector before 2.0, but scalar / vector was a very odd one to begin with (eg vector \ scalar doesn't exist and it never bothered anyone), and doesn't appear to be used (other than in error)

@ViralBShah
Copy link
Member

@StefanKarpinski you should probably take a look at this issue if you haven't already.

@ViralBShah
Copy link
Member

ViralBShah commented Nov 3, 2021

Did the linear algebra triage call happen? I think @antoine-levitt's analysis is spot on. Since this PR also removes vector \ vector, doesn't it need to be updated to leave that in and just remove the scaler version?

@ViralBShah
Copy link
Member

Also pinging @KristofferC

@ViralBShah ViralBShah marked this pull request as ready for review November 3, 2021 19:52
@ViralBShah ViralBShah marked this pull request as draft November 3, 2021 19:54
@andreasnoack
Copy link
Member

Did the linear algebra triage call happen?

Not yet.

@ViralBShah
Copy link
Member

@antoine-levitt I wonder if we should get this in. Can you rebase this? We'll run pkgeval once more and merge unless there is any further concern.

@antoine-levitt
Copy link
Contributor Author

Thanks for pinging, I'd forgotten this. I'm assuming you meant only the scalar / vector part? I opened up a new PR, #44358, for that. I'm keeping this one, which has the more breaking vector/vector and vector\vector

@ViralBShah
Copy link
Member

I suppose the more breaking stuff is a 2.0 thing.

@DilumAluthge
Copy link
Member

We have moved the LinearAlgebra stdlib to an external repo: https://github.com/JuliaLang/LinearAlgebra.jl

@antoine-levitt If you think that this PR is still relevant, please open a new PR on the LinearAlgebra.jl repo.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
breaking This change will break code forget me not PRs that one wants to make sure aren't forgotten linalg triage linear algebra Linear algebra
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Remove implicit pinvs of vectors
7 participants