169 похожих чатов

Придумалось вот следующее предложение по упрощению синтаксиса лямбда-выражений. Кто что скажет

по этому поводу?


1. Наряду с записью вида

x -> expr(x)

предлагается допустить более короткую эквивалентную запись

expr(.)

где точка обозначает позицию переменной в выражении, при этом эту точку иногда будет требоваться
заключать в дополнителные круглые скобки. Напимер, если

expr(x) = a*x + b

то тогда соответсвующее лямбда-выражение должно будет иметь вид

a*(.) + b

2. Наряду с записью вида

x -> expr(x,...,x)

опеределяющую функцию одной переменной, предлагается допускать также более короткую эквивалентную запись

expr(.,...,.)

где вместо многоточия предполагается конкретное число точек, разделенных запятыми.

Например, если определена некоторая функция f(x,y,z) 3-х переменных, то запись

f(x) = f(.,y,.)(x)

определяла бы функцию одной переменной.

Принятие этого предложения позволило бы, в частности, сделать более удобным использование broadcast.

Например, пусть определены некоторые переменные x, z, и итерируемый объект (например, вектор) u
тогда вместо

(v -> f(x,v,z)).(u)

можно будет писать просто

f(x,.,z).(u)

а вместо

(x -> f(x,y,x)).(u)

- писать

f(.,y,.).(u)

Кроме того, например,

f(., y, g(.)).(u)

в предлагаемых обозначениях означало бы то же самое, что и

(x -> f(x,y,g(x))).(u)

3. Предлагается также допускать использование точек с нижними числовыми индексами, для обозначения позиций
разных переменных (предполагается, что значения индексов произвольны, важно лишь, чтобы разным переменным
соответствовали бы разные индекся). Тогда, если определена некоторая функция нескольких переменных, например,
f(x,y,z,u), то наряду с определениями замыканий

(x,y) -> f(x,y,z,x)

(x,z) -> f(x,y,z,x)

определяющих функции меньшего числа переменных (2-х в данном случае), можно было бы использовать
эквивалентные им определения вида

f(.₁,.₂,z,.₁)

f(.₁,y,.₃,.₁)

4. Каррирование.

Предлагается наряду с нижними индексами у точек, обозначающих позиции переменнных, допустить также использование верхних индексов.
Тогда, для каррирования функции, вместо того, чтобы, например, писать

x -> y -> z -> f(x,y,z)

можно будет условиться писать просто

f(.¹, .², .³)

так, чтобы f(.¹, .², .³)(X)(Y)(Z) означало бы то же самое, что и (x -> y -> z -> f(x,y,z))(X)(Y)(Z)
где X, Y, Z - некоторые конкретные значения.

3 ответов

47 просмотров

Извиняюсь за смайлик. Это не потому, что предложение плохое, а потому что уже столько копий по этому поводу сломали.... Последнее, что я пользовал был Underscores.jl, но возможно что-то ещё люди придумали.

Такая идея обсуждалась на гитхабе, но обсуждение заглохло: https://github.com/JuliaLang/julia/pull/24990

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта