The maths traders in Australia were discussing whether it was possible in a maths trade to offer multiple items in exchange for one in a maths trade. No it's not, it doesn't even nearly work for reasons which are obvious to mathematicians. However I thought about it for a bit, and realised that with the introduction of a pricing mechanism, there can be such a trade. So I borrowed some symbols from the Z Notation (in which I was trained as an undergrad) and wrote this spec:
Let I be the set of items in the trade.
Let U be the set of users in the trade.
Let P be the set of prices, objects that can be summed and are totally ordered.
# every item has an owner, "
" means total function
owns : I
U
# if you don't own anything you're not in trade
ran(owns) = U
# some people assign values to some things, "
" means partial function
values : U
I
P
# For each user u, there is a function vu, which is the values that user places on items
vu = { (i,p) | (u,i)
p
values }
# and that user at least values the things they own
u:U
owns~
{u}
dom(vu)
# Then a valid solution to the trade is an assignment of items to users
s : I
U
# the items received by u are
ru = s~
{u}data:image/s3,"s3://crabby-images/956de/956defd5ca7a92e8253c08374a5ea034949cd160" alt="\rimg"
# the items sent by u are
su = owns~
{u}
ran(s)
# such that nothing is assigned to the person it came from
s
owns = data:image/s3,"s3://crabby-images/e428f/e428fb9450f2d612f5c3e3f0d66c497020869053" alt="\emptyset"
# and everyone gets a bargain, by their own personal pricing rules
u:ran(s)
Σ (i
ru) vu(i)
Σ (i
su) vu(i)
# For a solution to be useful, it must be non-trivial:
s
data:image/s3,"s3://crabby-images/e428f/e428fb9450f2d612f5c3e3f0d66c497020869053" alt="\emptyset"
# and furthermore, we would like to restrict ourselves to minimal solutions so as to not make offered trades incomprehensibly complex, so if t is a solution, then t is not a subset of s (can't find the right symbols to write that!)
Let I be the set of items in the trade.
Let U be the set of users in the trade.
Let P be the set of prices, objects that can be summed and are totally ordered.
# every item has an owner, "
data:image/s3,"s3://crabby-images/3effc/3effcaa8270fae0a67d959c01edd8306d8a769e7" alt="\fun"
owns : I
data:image/s3,"s3://crabby-images/3effc/3effcaa8270fae0a67d959c01edd8306d8a769e7" alt="\fun"
# if you don't own anything you're not in trade
ran(owns) = U
# some people assign values to some things, "
data:image/s3,"s3://crabby-images/cee95/cee9517fda010555e9441e4dcb19c6a66d6a7ef5" alt="\pfun"
values : U
data:image/s3,"s3://crabby-images/174eb/174ebd4f02d69e547f9d0aeb670d0067589e61aa" alt="\cross"
data:image/s3,"s3://crabby-images/cee95/cee9517fda010555e9441e4dcb19c6a66d6a7ef5" alt="\pfun"
# For each user u, there is a function vu, which is the values that user places on items
vu = { (i,p) | (u,i)
data:image/s3,"s3://crabby-images/e4af8/e4af864497dfc165d9c66f06f3e67e81b9e3e48c" alt="\mapsto"
data:image/s3,"s3://crabby-images/23643/23643256aa9a226d0b6ac76fa23fbb5d2d3147db" alt="\in"
# and that user at least values the things they own
data:image/s3,"s3://crabby-images/6dfdf/6dfdf31e6db5e10b56acba737cdb18381e9b8185" alt="\forall"
data:image/s3,"s3://crabby-images/4c914/4c914b236eca7a758bce62ac9ad8e5505574973e" alt="@"
data:image/s3,"s3://crabby-images/99840/998408656d06b16b93fba5bac168ab549311b751" alt="\limg"
data:image/s3,"s3://crabby-images/956de/956defd5ca7a92e8253c08374a5ea034949cd160" alt="\rimg"
data:image/s3,"s3://crabby-images/e2f30/e2f30dacece5fceabf4003821b079b813eafb45a" alt="\subseteq"
# Then a valid solution to the trade is an assignment of items to users
s : I
data:image/s3,"s3://crabby-images/cee95/cee9517fda010555e9441e4dcb19c6a66d6a7ef5" alt="\pfun"
# the items received by u are
ru = s~
data:image/s3,"s3://crabby-images/99840/998408656d06b16b93fba5bac168ab549311b751" alt="\limg"
data:image/s3,"s3://crabby-images/956de/956defd5ca7a92e8253c08374a5ea034949cd160" alt="\rimg"
# the items sent by u are
su = owns~
data:image/s3,"s3://crabby-images/99840/998408656d06b16b93fba5bac168ab549311b751" alt="\limg"
data:image/s3,"s3://crabby-images/956de/956defd5ca7a92e8253c08374a5ea034949cd160" alt="\rimg"
data:image/s3,"s3://crabby-images/7d380/7d380fe2edefde04ad8eccc40168ec5903f88a78" alt="\cat"
# such that nothing is assigned to the person it came from
s
data:image/s3,"s3://crabby-images/a79d1/a79d1fa33b02553db028e04e38aa40c18ec7b5bc" alt="\cap"
data:image/s3,"s3://crabby-images/e428f/e428fb9450f2d612f5c3e3f0d66c497020869053" alt="\emptyset"
# and everyone gets a bargain, by their own personal pricing rules
data:image/s3,"s3://crabby-images/6dfdf/6dfdf31e6db5e10b56acba737cdb18381e9b8185" alt="\forall"
data:image/s3,"s3://crabby-images/4c914/4c914b236eca7a758bce62ac9ad8e5505574973e" alt="@"
data:image/s3,"s3://crabby-images/23643/23643256aa9a226d0b6ac76fa23fbb5d2d3147db" alt="\in"
data:image/s3,"s3://crabby-images/1a3c1/1a3c1d275b0388f7b9843f2c8d78ae49363cee4a" alt="\geq"
data:image/s3,"s3://crabby-images/23643/23643256aa9a226d0b6ac76fa23fbb5d2d3147db" alt="\in"
# For a solution to be useful, it must be non-trivial:
s
data:image/s3,"s3://crabby-images/390b5/390b53920b3bc9a3f0eb5de776f3f8e057654308" alt="\neq"
data:image/s3,"s3://crabby-images/e428f/e428fb9450f2d612f5c3e3f0d66c497020869053" alt="\emptyset"
# and furthermore, we would like to restrict ourselves to minimal solutions so as to not make offered trades incomprehensibly complex, so if t is a solution, then t is not a subset of s (can't find the right symbols to write that!)
It occurs to me that blogspot is maybe not the ideal medium for writing specifications.