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

[WIP] New Design #8

Draft
wants to merge 24 commits into
base: master
Choose a base branch
from
Draft

[WIP] New Design #8

wants to merge 24 commits into from

Conversation

utensil
Copy link
Member

@utensil utensil commented Jul 12, 2020

Work-in-progress.

What's a point? How do we tell this concept to the computer? Do we draw a point? Or do we went to analytic geometry and give it a coordinate? It turns out we don't need to do either, the former is infeasible and the latter is the worst idea in formalizing.

```lean
constant Point : Type
Copy link
Member

Choose a reason for hiding this comment

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

What if I have a pointXY structure, and I want to apply the theorems about Point to it?

Copy link
Member Author

@utensil utensil Jul 13, 2020

Choose a reason for hiding this comment

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

This paragraph discusses how to do abstract reasoning without ever coming back to the concrete world. There was supposed to be a paragraph about what if we need to link back to the concrete world then that's where type classes come in. And I should also discuss using class v.s. structure (1:1 v.s. 1:n) as pointed out by Kevin Buzzard.


/--
-/
@[ancestor algebra]
Copy link
Member

Choose a reason for hiding this comment

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

What does this do that isn't covered by extends?

Copy link
Member Author

Choose a reason for hiding this comment

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

Still trying to figure out the exact effect, it shows up in group.defs in mathlib

Copy link
Member

Choose a reason for hiding this comment

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

Yeah, I've seen it before too, was hoping you'd worked out its meaning since I haven't yet...

Authors: Utensil Song

This file contains only imports which are just the lean files
that the authors draw inspirations from.
Copy link
Member

Choose a reason for hiding this comment

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

The goal here is a quick "jump to definition"?

Copy link
Member Author

Choose a reason for hiding this comment

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

Yes, only that. Since this is a branch so I'm a little casual about file organization and leave it by the side of the files I'm working on.

Copy link
Member

Choose a reason for hiding this comment

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

I like this idea, just would like a comment in this file pointing out it it can be used this way :)

(fᵣ_algebra_map_eq : fᵣ = algebra_map R G)
(fᵥ : V →+ G)
-- this is the weaker form of the contraction rule for vectors
(vector_contract' : ∀ v, ∃ r, fᵥ v * fᵥ v = fᵣ r )
Copy link
Member

Choose a reason for hiding this comment

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

Is this weak form useful? Is there a way we can have lean infer it from the strong form?

Copy link
Member Author

@utensil utensil Jul 13, 2020

Choose a reason for hiding this comment

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

Yes, this can be proven by the strong form.

I'm leaving the weak layer here because I want to be explicit about three layers that: purely just an ordinary algebra, having something about the linear map (the weak form demonstrate the usefulness of the linear maps but it could also be not there), and bundling a quadratic form.

The real issue between choosing the weak form or the strong form, is whether we assume a metric at the beginning. There are literatures assumes no metric or assume a non-symmetric bilinear form, and this layer can be useful to them.

Copy link
Member Author

Choose a reason for hiding this comment

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

It's more of a POC and I don't if we need them after some software engineering thinking. So far it can stay there and be in the way of nothing.

That's it. We don't need concrete types or computibility to reason about them. The semantic can end with their names and we don't need to know more underneath.

This is the key insight one must have before formalizing a piece of mathematics.

Copy link
Member Author

Choose a reason for hiding this comment

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

TODO: Add structure v.s. class here


```lean
class has_wedge (α : Type u) := (wedge : α → α → α)
class has_inner (α : Type u) := (inner : α → α → α)
Copy link
Member Author

Choose a reason for hiding this comment

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

has_inner assumes the result is real. It could be a more concrete instance of the general has_dot we have.


The latter presumably is already in mathlib and has a lot of structures and properties associated with it. We'll deal with that later.

As for geometric product, I'm thinking about the following short name instead of `geomprod`, `gp` etc.:
Copy link
Member Author

Choose a reason for hiding this comment

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

It turns out that gmul doesn't scale well, Scalar Product can't be smul because it's used by has_scalar which would be in our inheritance hierarchy.

Copy link
Member

Choose a reason for hiding this comment

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

Can't we have geometric_algebra.has_scalar_product.smul to distinguish from has_scalar.smul? Or do namespaces not work well here?

Copy link
Member Author

Choose a reason for hiding this comment

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

old structure is flat, so no matter where smul comes from, as long as it's in our inheritance hierarchy, it conflicts.

Better avoid it anyway.

-- export has_wedge (wedge)

local infix ⬝ := has_dot.dot
local infix ∧ := has_wedge.wedge
Copy link
Member Author

Choose a reason for hiding this comment

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

A serious problem is that wedge is globally reserved to infixr which has right associativity and conflicts with our wedge. local only evaded the problem temporarily.

Copy link
Member

@eric-wieser eric-wieser Jul 14, 2020

Choose a reason for hiding this comment

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

Can you elaborate on why right-associativity is an issue with an example?

Copy link
Member Author

Choose a reason for hiding this comment

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

Also it conflicts with logical AND

Co-authored-by: Eric Wieser <[email protected]>
```lean
class has_ga_wedge (α : Type u) extends has_wedge :=
(defeq : ∀ a b : α, a ∧ b = (a ∘ b - b ∘ a) / 2)
```
Copy link
Member Author

Choose a reason for hiding this comment

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

This didn't happen yet.

(R : Type ur) [field R]
(V : Type uv) [add_comm_group V] [vector_space R V]
(G : Type ug) [ring G]
extends algebra R G
Copy link
Member Author

Choose a reason for hiding this comment

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

has_geom_prod will return here. Haven't figure out how to and how it surves the purpose yet.

class semi_geometric_algebra
(R : Type ur) [field R]
(V : Type uv) [add_comm_group V] [vector_space R V]
(G : Type ug) [ring G]
Copy link
Member Author

Choose a reason for hiding this comment

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

It seems that I can't leave them to variables because that would cause failure to use either semi_geometric_algebra G or semi_geometric_algebra R V G. They still stick here.

@utensil utensil marked this pull request as draft July 14, 2020 04:53
Comment on lines +35 to +46
reserve infix ` ⊛ `:70
local infix ` ⊛ ` := has_scalar_prod.scalar_prod

reserve infix ` ⊙ `:70
reserve infix ` ⊠ `:70
local infix ` ⊙ ` := has_symm_prod.symm_prod
local infix ` ⊠ ` := has_asymm_prod.asymm_prod

reserve infix ` ⨼ `:70
reserve infix ` ⨽ `:70
local infix ⨼ := has_left_contract.left_contract
local infix ⨽ := has_right_contract.right_contract
Copy link
Member

Choose a reason for hiding this comment

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

Shorter and equivalent as:

Suggested change
reserve infix ` ⊛ `:70
local infix ` ⊛ ` := has_scalar_prod.scalar_prod
reserve infix ` ⊙ `:70
reserve infix ` ⊠ `:70
local infix ` ⊙ ` := has_symm_prod.symm_prod
local infix ` ⊠ ` := has_asymm_prod.asymm_prod
reserve infix ` ⨼ `:70
reserve infix ` ⨽ `:70
local infix ⨼ := has_left_contract.left_contract
local infix ⨽ := has_right_contract.right_contract
local infix ` ⊛ `:70 := has_scalar_prod.scalar_prod
local infix ` ⊙ `:70 := has_symm_prod.symm_prod
local infix ` ⊠ `:70 := has_asymm_prod.asymm_prod
local infix ` ⨼ `:70 := has_left_contract.left_contract
local infix ` ⨽ `:70 := has_right_contract.right_contract

Copy link
Member

Choose a reason for hiding this comment

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

(unless you know a difference that I don't)

Comment on lines +27 to +28
-- export has_dot (dot)
-- export has_wedge (wedge)
Copy link
Member

Choose a reason for hiding this comment

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

What's the idea behind these?

Copy link
Member Author

@utensil utensil Jul 20, 2020

Choose a reason for hiding this comment

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

This exports a wedge function, without has_wedge.

Copy link
Member

Choose a reason for hiding this comment

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

Ah, so I should read this as the python wedge = has_wedge.wedge?

Copy link
Member Author

Choose a reason for hiding this comment

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

Not sure about the full extent of this, I saw this in code, check out what it seems to mean and commented it out because I thought it's not useful for our purpose.

@@ -0,0 +1,155 @@
import ring_theory.algebra
Copy link
Member

Choose a reason for hiding this comment

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

Mind adding a link to the zulip thread here?

Copy link
Member Author

Choose a reason for hiding this comment

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

Will do

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.

2 participants