Skip to content

Commit

Permalink
Merge branch 'master' into refactor-standard-pullback
Browse files Browse the repository at this point in the history
  • Loading branch information
fredrik-bakke authored Feb 27, 2024
2 parents 6dcdb4f + bfb898f commit 4dc790e
Show file tree
Hide file tree
Showing 25 changed files with 1,954 additions and 303 deletions.
12 changes: 7 additions & 5 deletions .github/workflows/profiling.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -67,12 +67,14 @@ jobs:

- name: Prepare new revision of the profiling website
run: |
cd repo
mkdir -p benchmark-website
cp website/benchmarks/index.html benchmark-website/
cp ../benchmark-cache/data.* benchmark-website/
echo 'window.BENCHMARK_DATA =' | cat - ../benchmark-cache/data.json > benchmark-website/data.js
cp repo/website/benchmarks/index.html benchmark-website/
cp benchmark-cache/data.* benchmark-website/
echo 'window.BENCHMARK_DATA =' | cat - benchmark-cache/data.json > benchmark-website/data.js
- name: Deploy the new profiling website
env:
NETLIFY_SITE_ID: ${{ secrets.PERF_SITE_ID }}
NETLIFY_AUTH_TOKEN: ${{ secrets.PERF_SITE_KEY }}
run: |
npx netlify-cli deploy --dir=benchmark-website
npx netlify-cli deploy --prod --dir=benchmark-website
10 changes: 6 additions & 4 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,10 +27,7 @@
"files.exclude": {
"MAlonzo/": true,
"**/MAlonzo/": true,
"_build/": true,
"**/_build/": true,
"agdaFiles": true,
"src/temp/": true
"agdaFiles": true
},

// Snippet setup
Expand Down Expand Up @@ -94,6 +91,11 @@
"editor.autoClosingBrackets": "never"
},

"[makefile]": {
"editor.insertSpaces": false,
"editor.detectIndentation": true
},

"[markdown]": {
"editor.rulers": [80],
"editor.quickSuggestions": {
Expand Down
77 changes: 59 additions & 18 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -25,24 +25,24 @@ AGDA ?= agda $(AGDAVERBOSE) $(AGDARTS)
TIME ?= time

METAFILES := \
ART.md \
CITE-THIS-LIBRARY.md \
CODINGSTYLE.md \
CONTRIBUTING.md \
CONTRIBUTORS.md \
FILE-CONVENTIONS.md \
DESIGN-PRINCIPLES.md \
GRANT-ACKNOWLEDGEMENTS.md \
HOME.md \
HOWTO-INSTALL.md \
LICENSE.md \
MIXFIX-OPERATORS.md \
MAINTAINERS.md \
README.md \
STATEMENT-OF-INCLUSION.md \
SUMMARY.md \
TEMPLATE.lagda.md \
USERS.md \
ART.md \
CITE-THIS-LIBRARY.md \
CODINGSTYLE.md \
CONTRIBUTING.md \
CONTRIBUTORS.md \
FILE-CONVENTIONS.md \
DESIGN-PRINCIPLES.md \
GRANT-ACKNOWLEDGEMENTS.md \
HOME.md \
HOWTO-INSTALL.md \
LICENSE.md \
MIXFIX-OPERATORS.md \
MAINTAINERS.md \
README.md \
STATEMENT-OF-INCLUSION.md \
SUMMARY.md \
TEMPLATE.lagda.md \
USERS.md \

.PHONY: agdaFiles
agdaFiles:
Expand Down Expand Up @@ -75,6 +75,47 @@ check: ./src/everything.lagda.md
check-profile: ./src/everything.lagda.md
${AGDA} ${AGDAPROFILEFLAGS} $?

# Base directory where Agda interface files are stored
BUILD_DIR := ./_build
# Directory for temporary files
TEMP_DIR := ./temp
# Convert module path to directory path (replace dots with slashes)
MODULE_DIR = $(subst .,/,$(MODULE))


# Default agda arguments for `profile-module`
PROFILE_MODULE_AGDA_ARGS ?= --profile=definitions
# Target for profiling the typechecking a single module
.PHONY: profile-module
profile-module:
@if [ -z "$(MODULE)" ]; then \
echo "\033[0;31mError: MODULE variable is not set.\033[0m"; \
echo "\033[0;31mUsage: make check-module MODULE=\"YourModuleName\"\033[0m"; \
exit 1; \
fi
@# Attempt to delete the interface file only if the build directory exists
@echo "\033[0;32mAttempting to delete interface file for $(MODULE)\033[0m"
@find $(BUILD_DIR) -type f -path "*/agda/src/$(MODULE_DIR).agdai" -exec rm -f {} \+ 2>/dev/null || \
echo "\033[0;31m$(BUILD_DIR) directory does not exist, skipping deletion of interface files.\033[0m"
@# Ensure the temporary directory exists
@mkdir -p $(TEMP_DIR)
@# Profile typechecking the module and capture the output in the temp directory, also display on terminal
@echo "\033[0;32mProfiling typechecking of $(MODULE)\033[0m"
@$(AGDA) $(PROFILE_MODULE_AGDA_ARGS) src/$(MODULE_DIR).lagda.md 2>&1 | tee $(TEMP_DIR)/typecheck_output.txt
@# Check for additional modules being typechecked by looking for any indented "Checking" line
@if grep -E "^\s+Checking " $(TEMP_DIR)/typecheck_output.txt > /dev/null; then \
echo "\033[0;31mOther modules were also checked. Repeating profiling after deleting interface file again.\033[0m"; \
find $(BUILD_DIR) -type f -path "*/agda/src/$(MODULE_DIR).agdai" -exec rm -f {} \+; \
$(AGDA) $(PROFILE_MODULE_AGDA_ARGS) src/$(MODULE_DIR).lagda.md; \
else \
echo "\033[0;32mOnly $(MODULE) was checked. Profiling complete.\033[0m"; \
fi

@# Cleanup
@rm -f $(TEMP_DIR)/typecheck_output.txt



agda-html: ./src/everything.lagda.md
@rm -rf ./docs/
@mkdir -p ./docs/
Expand Down
2 changes: 2 additions & 0 deletions src/elementary-number-theory.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ open import elementary-number-theory.collatz-conjecture public
open import elementary-number-theory.commutative-semiring-of-natural-numbers public
open import elementary-number-theory.congruence-integers public
open import elementary-number-theory.congruence-natural-numbers public
open import elementary-number-theory.cross-multiplication-difference-integer-fractions public
open import elementary-number-theory.cubes-natural-numbers public
open import elementary-number-theory.decidable-dependent-function-types public
open import elementary-number-theory.decidable-total-order-natural-numbers public
Expand Down Expand Up @@ -73,6 +74,7 @@ open import elementary-number-theory.legendre-symbol public
open import elementary-number-theory.lower-bounds-natural-numbers public
open import elementary-number-theory.maximum-natural-numbers public
open import elementary-number-theory.maximum-standard-finite-types public
open import elementary-number-theory.mediant-integer-fractions public
open import elementary-number-theory.mersenne-primes public
open import elementary-number-theory.minimum-natural-numbers public
open import elementary-number-theory.minimum-standard-finite-types public
Expand Down
14 changes: 14 additions & 0 deletions src/elementary-number-theory/addition-integers.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -536,6 +536,20 @@ is-positive-add-ℤ {inr (inr (succ-ℕ x))} {inr (inr y)} H K =
is-positive-succ-ℤ
( is-nonnegative-is-positive-ℤ
( is-positive-add-ℤ {inr (inr x)} {inr (inr y)} star star))

is-positive-add-nonnegative-positive-ℤ :
{x y : ℤ} is-nonnegative-ℤ x is-positive-ℤ y is-positive-ℤ (x +ℤ y)
is-positive-add-nonnegative-positive-ℤ {inr (inl x)} {y} H H' =
is-positive-eq-ℤ refl H'
is-positive-add-nonnegative-positive-ℤ {inr (inr x)} {y} H H' =
is-positive-add-ℤ {inr (inr x)} {y} H H'

is-positive-add-positive-nonnegative-ℤ :
{x y : ℤ} is-positive-ℤ x is-nonnegative-ℤ y is-positive-ℤ (x +ℤ y)
is-positive-add-positive-nonnegative-ℤ {x} {y} H H' =
is-positive-eq-ℤ
( commutative-add-ℤ y x)
( is-positive-add-nonnegative-positive-ℤ H' H)
```

### The inclusion of ℕ into ℤ preserves addition
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,219 @@
# The cross-multiplication difference of two integer fractions

```agda
module elementary-number-theory.cross-multiplication-difference-integer-fractions where
```

<details><summary>Imports</summary>

```agda
open import elementary-number-theory.addition-integers
open import elementary-number-theory.difference-integers
open import elementary-number-theory.integer-fractions
open import elementary-number-theory.integers
open import elementary-number-theory.multiplication-integers

open import foundation.action-on-identifications-functions
open import foundation.dependent-pair-types
open import foundation.identity-types
open import foundation.negation
open import foundation.propositions
```

</details>

## Idea

The
{{#concept "cross-multiplication difference" Agda=cross-mul-diff-fraction-ℤ}} of
two [integer fractions](elementary-number-theory.integer-fractions.md) `a/b` and
`c/d` is the [difference](elementary-number-theory.difference-integers.md) of
the [products](elementary-number-theory.multiplication-integers.md) of the
numerator of each fraction with the denominator of the other: `c * b - a * d`.

## Definitions

### The cross-multiplication difference of two fractions

```agda
cross-mul-diff-fraction-ℤ : fraction-ℤ fraction-ℤ
cross-mul-diff-fraction-ℤ x y =
diff-ℤ
( numerator-fraction-ℤ y *ℤ denominator-fraction-ℤ x)
( numerator-fraction-ℤ x *ℤ denominator-fraction-ℤ y)
```

## Properties

### Swapping the fractions changes the sign of the cross-multiplication difference

```agda
skew-commutative-cross-mul-diff-fraction-ℤ :
(x y : fraction-ℤ)
Id
( neg-ℤ (cross-mul-diff-fraction-ℤ x y))
( cross-mul-diff-fraction-ℤ y x)
skew-commutative-cross-mul-diff-fraction-ℤ x y =
distributive-neg-diff-ℤ
( numerator-fraction-ℤ y *ℤ denominator-fraction-ℤ x)
( numerator-fraction-ℤ x *ℤ denominator-fraction-ℤ y)
```

### Two fractions are similar when their cross-multiplication difference is zero

```agda
module _
(x y : fraction-ℤ)
where

is-zero-cross-mul-diff-sim-fraction-ℤ :
sim-fraction-ℤ x y
is-zero-ℤ (cross-mul-diff-fraction-ℤ x y)
is-zero-cross-mul-diff-sim-fraction-ℤ H =
is-zero-diff-ℤ (inv H)

sim-is-zero-coss-mul-diff-fraction-ℤ :
is-zero-ℤ (cross-mul-diff-fraction-ℤ x y)
sim-fraction-ℤ x y
sim-is-zero-coss-mul-diff-fraction-ℤ H = inv (eq-diff-ℤ H)
```

## The transitive-additive property for the cross-multiplication difference

Given three fractions `a/b`, `x/y` and `m/n`, the pairwise cross-multiplication
differences satisfy a transitive-additive property:

```text
y * (m * b - a * n) = b * (m * y - x * n) + n * (x * b - a * y)
```

```agda
lemma-add-cross-mul-diff-fraction-ℤ :
(p q r : fraction-ℤ)
Id
( add-ℤ
( denominator-fraction-ℤ p *ℤ cross-mul-diff-fraction-ℤ q r)
( denominator-fraction-ℤ r *ℤ cross-mul-diff-fraction-ℤ p q))
( denominator-fraction-ℤ q *ℤ cross-mul-diff-fraction-ℤ p r)
lemma-add-cross-mul-diff-fraction-ℤ
(np , dp , hp)
(nq , dq , hq)
(nr , dr , hr) =
equational-reasoning
add-ℤ
(dp *ℤ (nr *ℤ dq -ℤ nq *ℤ dr))
(dr *ℤ (nq *ℤ dp -ℤ np *ℤ dq))
= add-ℤ
(dp *ℤ (nr *ℤ dq) -ℤ dp *ℤ (nq *ℤ dr))
(dr *ℤ (nq *ℤ dp) -ℤ dr *ℤ (np *ℤ dq))
by
ap-add-ℤ
( inv (linear-diff-left-mul-ℤ dp (nr *ℤ dq) (nq *ℤ dr)))
( inv (linear-diff-left-mul-ℤ dr (nq *ℤ dp) (np *ℤ dq)))
= diff-ℤ
(dp *ℤ (nr *ℤ dq) +ℤ dr *ℤ (nq *ℤ dp))
(dp *ℤ (nq *ℤ dr) +ℤ dr *ℤ (np *ℤ dq))
by
interchange-law-add-diff-ℤ
( mul-ℤ dp ( mul-ℤ nr dq))
( mul-ℤ dp ( mul-ℤ nq dr))
( mul-ℤ dr ( mul-ℤ nq dp))
( mul-ℤ dr ( mul-ℤ np dq))
= diff-ℤ
(dq *ℤ (nr *ℤ dp) +ℤ dr *ℤ (nq *ℤ dp))
(dr *ℤ (nq *ℤ dp) +ℤ dq *ℤ (np *ℤ dr))
by
ap-diff-ℤ
( ap-add-ℤ
( lemma-interchange-mul-ℤ dp nr dq)
( refl))
( ap-add-ℤ
( lemma-interchange-mul-ℤ dp nq dr)
( lemma-interchange-mul-ℤ dr np dq))
= diff-ℤ
(dq *ℤ (nr *ℤ dp) +ℤ dr *ℤ (nq *ℤ dp))
((dq *ℤ (np *ℤ dr)) +ℤ (dr *ℤ (nq *ℤ dp)))
by
ap
( diff-ℤ (dq *ℤ (nr *ℤ dp) +ℤ dr *ℤ (nq *ℤ dp)))
( commutative-add-ℤ (dr *ℤ (nq *ℤ dp)) (dq *ℤ (np *ℤ dr)))
= (dq *ℤ (nr *ℤ dp)) -ℤ (dq *ℤ (np *ℤ dr))
by
right-translation-diff-ℤ
(dq *ℤ (nr *ℤ dp))
(dq *ℤ (np *ℤ dr))
(dr *ℤ (nq *ℤ dp))
= dq *ℤ (nr *ℤ dp -ℤ np *ℤ dr)
by linear-diff-left-mul-ℤ dq (nr *ℤ dp) (np *ℤ dr)
where
lemma-interchange-mul-ℤ : (a b c : ℤ) (a *ℤ (b *ℤ c)) = (c *ℤ (b *ℤ a))
lemma-interchange-mul-ℤ a b c =
inv (associative-mul-ℤ a b c) ∙
ap (mul-ℤ' c) (commutative-mul-ℤ a b) ∙
commutative-mul-ℤ (b *ℤ a) c

lemma-left-sim-cross-mul-diff-fraction-ℤ :
(a a' b : fraction-ℤ)
sim-fraction-ℤ a a'
Id
( denominator-fraction-ℤ a *ℤ cross-mul-diff-fraction-ℤ a' b)
( denominator-fraction-ℤ a' *ℤ cross-mul-diff-fraction-ℤ a b)
lemma-left-sim-cross-mul-diff-fraction-ℤ a a' b H =
equational-reasoning
( denominator-fraction-ℤ a *ℤ cross-mul-diff-fraction-ℤ a' b)
= ( add-ℤ
( denominator-fraction-ℤ a' *ℤ cross-mul-diff-fraction-ℤ a b)
( denominator-fraction-ℤ b *ℤ cross-mul-diff-fraction-ℤ a' a))
by inv (lemma-add-cross-mul-diff-fraction-ℤ a' a b)
= ( add-ℤ
( denominator-fraction-ℤ a' *ℤ cross-mul-diff-fraction-ℤ a b)
( zero-ℤ))
by
ap
( add-ℤ
( denominator-fraction-ℤ a' *ℤ cross-mul-diff-fraction-ℤ a b))
( ( ap
( mul-ℤ (denominator-fraction-ℤ b))
( is-zero-cross-mul-diff-sim-fraction-ℤ a' a H')) ∙
( right-zero-law-mul-ℤ (denominator-fraction-ℤ b)))
= denominator-fraction-ℤ a' *ℤ cross-mul-diff-fraction-ℤ a b
by
right-unit-law-add-ℤ
( denominator-fraction-ℤ a' *ℤ cross-mul-diff-fraction-ℤ a b)
where
H' : sim-fraction-ℤ a' a
H' = symmetric-sim-fraction-ℤ a a' H

lemma-right-sim-cross-mul-diff-fraction-ℤ :
(a b b' : fraction-ℤ)
sim-fraction-ℤ b b'
Id
( denominator-fraction-ℤ b *ℤ cross-mul-diff-fraction-ℤ a b')
( denominator-fraction-ℤ b' *ℤ cross-mul-diff-fraction-ℤ a b)
lemma-right-sim-cross-mul-diff-fraction-ℤ a b b' H =
equational-reasoning
( denominator-fraction-ℤ b *ℤ cross-mul-diff-fraction-ℤ a b')
= ( add-ℤ
( denominator-fraction-ℤ a *ℤ cross-mul-diff-fraction-ℤ b b')
( denominator-fraction-ℤ b' *ℤ cross-mul-diff-fraction-ℤ a b))
by inv (lemma-add-cross-mul-diff-fraction-ℤ a b b')
= ( add-ℤ
( zero-ℤ)
( denominator-fraction-ℤ b' *ℤ cross-mul-diff-fraction-ℤ a b))
by
ap
( add-ℤ' (denominator-fraction-ℤ b' *ℤ cross-mul-diff-fraction-ℤ a b))
( ( ap
( mul-ℤ (denominator-fraction-ℤ a))
( is-zero-cross-mul-diff-sim-fraction-ℤ b b' H)) ∙
( right-zero-law-mul-ℤ (denominator-fraction-ℤ a)))
= denominator-fraction-ℤ b' *ℤ cross-mul-diff-fraction-ℤ a b
by
left-unit-law-add-ℤ
( denominator-fraction-ℤ b' *ℤ cross-mul-diff-fraction-ℤ a b)
```

## External links

- [Cross-multiplication](https://en.wikipedia.org/wiki/Cross-multiplication) at
Wikipedia
Loading

0 comments on commit 4dc790e

Please sign in to comment.