Forwarded from 羽毛的小白板
😶 接个外快写一下 Android App in Kotlin
刚才上 #Bilibili 站,发现国人做的语音处理方面的项目还真是多啊... Powerpoid、Emvoice
排除 Sharpkey 这种算是老项目(指公开开发时间)和 Upslink(主要是基于 Praat 的音高修正)、Moresampler、MUTA 这种有源头的,一大堆新引擎... 这是怎么了呢?
排除 Sharpkey 这种算是老项目(指公开开发时间)和 Upslink(主要是基于 Praat 的音高修正)、Moresampler、MUTA 这种有源头的,一大堆新引擎... 这是怎么了呢?
duangsuse::Echo
😐 我想看看我的天赋和学习能力到了什么程度
Android 开发也不错的选择(
设计模式,我上面默写的那个你也来默写一下(
设计模式,我上面默写的那个你也来默写一下(
Telegram
duangsuse::Echo
最近深受神经质困扰
https://github.com/imufun/rebase-server
这个项目你们觉得复杂么...
我看对我来说如果我觉得某个东西不复杂,那就是要能把所有代码都默写下来... 要不然我就会很失望,就是说这种工程量我一天内必须能做完... 🤔
要求还比较高... 因为我记性不是很好,目前正在练习。
平均会去记忆一些符号... 默写一下某个 Validator @interface:
🤔其实考虑一下,好像平时默写出这种东西所需要的能力和写函数式和归纳证明什么的的能力不…
https://github.com/imufun/rebase-server
这个项目你们觉得复杂么...
我看对我来说如果我觉得某个东西不复杂,那就是要能把所有代码都默写下来... 要不然我就会很失望,就是说这种工程量我一天内必须能做完... 🤔
要求还比较高... 因为我记性不是很好,目前正在练习。
平均会去记忆一些符号... 默写一下某个 Validator @interface:
🤔其实考虑一下,好像平时默写出这种东西所需要的能力和写函数式和归纳证明什么的的能力不…
duangsuse::Echo
#Math Tips: 为什么任何数乘 0 都得 0,乘 1 都得原数?(放松一下系列) (好吧,虽然我平时都不是很轻松(大嘘)) 考虑一下自然数(正整数)的定义 data Nat = Zero | Succ Nat 我们这么说:一个自然数可能是零,也可以是另一个自然数的『后继元(Succeeder)』 那么 1 就是 Succ Zero(1 + 0)、3 就是 Succ (Succ (Succ Zero)) (1 + 1 + 1 + 0) 那么,对于 Nat 这个 GADT(不准喷为什么用 GADT…
对了,上面的那个 Nat 的确是 Coinductive 的,来源冰封博客
... 可是我不知道怎么证明也不可以啊(迫真
(为了证明我的确有基本 inductive 的证明能力,现在默写某关于 fold operator 相关属性的证明:
使用 universality 属性展开 sum 定义:
... 可是我不知道怎么证明也不可以啊(迫真
(为了证明我的确有基本 inductive 的证明能力,现在默写某关于 fold operator 相关属性的证明:
fold :: (a -> b) -> b -> ([a] -> b)证明
fold f v [] = v
fold f v (x : xs) = f x (fold f v xs)
sum = fold (+) 0
((+1) . sum) = fold (+) 1:使用 universality 属性展开 sum 定义:
g [] = v(在这里
g (x:xs) = f x (g xs)
<=> g = fold f v
((+1) . sum []) = 0
((+1) . sum (x:xs)) = (+) x (((+1) . sum) xs)
g 是 ((+1) . sum)、. 是 compose (函数组合)函数,定义为)(.) :: (b -> c) -> (a -> b) -> a -> c简化变形
(. f g) = \x -> f (g x)
sum [] + 1 = 0 + 1
sum (x:xs) = (x + (sum xs)) + 1
第一个等式sum [] + 1第二个等式
= 0 + 1
= 1
sum (x : xs)归纳出来了
= (x + (sum xs)) + 1
{- 加法结合律 -}
= x + (sum xs + 1)
duangsuse::Echo
#Math Tips: 为什么任何数乘 0 都得 0,乘 1 都得原数?(放松一下系列) (好吧,虽然我平时都不是很轻松(大嘘)) 考虑一下自然数(正整数)的定义 data Nat = Zero | Succ Nat 我们这么说:一个自然数可能是零,也可以是另一个自然数的『后继元(Succeeder)』 那么 1 就是 Succ Zero(1 + 0)、3 就是 Succ (Succ (Succ Zero)) (1 + 1 + 1 + 0) 那么,对于 Nat 这个 GADT(不准喷为什么用 GADT…
后来想想,其实
- add
这样是不是对于 Coinductive 证明来说就能直接得证了呢?
add (Succ m) Zero因为两个参数都修改了所以不能只考虑第二个参数是 Zero 的情况,到不如再抽一下成
= add m (Succ Zero)
add Zero n = n其实它就是说
add (Succ m) n
= add m (Succ n)
- add
0 n = n
- add m n = add (m - 1) (n + 1)
最终的『基线』其实就是 m = 0,然后每一层递归都把 m 减去一(匹配掉一个 Succ,也即『取前驱元 predecessor』) n 加上 1(取后继元),最终就是『往 n 上加 m 次 1』,就实现了加法的语义这样是不是对于 Coinductive 证明来说就能直接得证了呢?
duangsuse::Echo
😐 我想看看我的天赋和学习能力到了什么程度
大佬也来学 Agda 什么的吧(
https://ice1000.org/lagda/MuGenHackingToTheGate.html 这个比较偏向入门级别
顺便问问:大佬的 GitHub 在哪里呢?(其实是想问问之前那个 AST 处理的程序是怎么写的了解一下)
大佬看没看过 GoF 的那些 OO 模式的本本呢? 🤔
觉得好像看过会更有底气一些,我没看过... 所̶以̶经̶常̶会̶被̶ ̶A̶n̶d̶r̶o̶i̶d̶ ̶的̶开̶发̶者̶们̶吊打̶̶ #Android
觉得好像自己会画图更有底气一些,我没画过多少
其̶实̶我̶很̶想̶吊̶打̶做̶ ̶A̶n̶d̶r̶o̶i̶d̶ ̶开̶发̶的̶,̶可̶是̶不̶了̶解̶ ̶O̶O̶ ̶没̶底̶气̶
#Tools #Linux 删除线生成。
https://ice1000.org/lagda/MuGenHackingToTheGate.html 这个比较偏向入门级别
顺便问问:大佬的 GitHub 在哪里呢?(其实是想问问之前那个 AST 处理的程序是怎么写的了解一下)
大佬看没看过 GoF 的那些 OO 模式的本本呢? 🤔
觉得好像看过会更有底气一些,我没看过... 所̶以̶经̶常̶会̶被̶ ̶A̶n̶d̶r̶o̶i̶d̶ ̶的̶开̶发̶者̶们̶吊打̶̶ #Android
觉得好像自己会画图更有底气一些,我没画过多少
其̶实̶我̶很̶想̶吊̶打̶做̶ ̶A̶n̶d̶r̶o̶i̶d̶ ̶开̶发̶的̶,̶可̶是̶不̶了̶解̶ ̶O̶O̶ ̶没̶底̶气̶
#Tools #Linux 删除线生成。
strikeout() { sed 's/\(.\)/\1̶/g' <<<$1 }
zstrikeout() { zenity --entry --text=请复制 --entry-text=`strikeout $1` }
strikeout 'Unicode Strikeout composition test' | xclip
duangsuse::Echo
😐 我想看看我的天赋和学习能力到了什么程度
大佬要不要试试入门 ANN( #CS #PL
魔理沙学姐也写过这种文章
图论和函数式编程也挺好玩的
编译原理是个很实用的内容,我给 GeekAPK 搞的 GeekSpec DSL codegen 就是比较 naive 的一种应用(现在也没有写过自己的 LLVM 编译器,惭愧)
大佬的博客好像没有找到(给个链接?
如果没事的话写点玩转 PostgresSQL 文也可以的 👍
我觉得这个东西还挺好玩的 ,可是有点难... 🤔
尤其是数学我 ****🐔🐒***&%$^$@$
魔理沙学姐也写过这种文章
图论和函数式编程也挺好玩的
编译原理是个很实用的内容,我给 GeekAPK 搞的 GeekSpec DSL codegen 就是比较 naive 的一种应用(现在也没有写过自己的 LLVM 编译器,惭愧)
大佬的博客好像没有找到(给个链接?
如果没事的话写点玩转 PostgresSQL 文也可以的 👍
我觉得这个东西还挺好玩的 ,可是有点难... 🤔
尤其是数学我 ****🐔🐒***&%$^$@$
Cnblogs
前馈全连接神经网络和函数逼近、时间序列预测、手写数字识别 - Conmajia - 博客园
Andrew Kirillov 著 Conmajia 译 2019 年 1 月 12 日 原文发表于 CodeProject(2018 年 9 月 28 日). 中文版有小幅修改,已获作者本人授权.
duangsuse::Echo
我去,这么点钱房租够么... #China #Life .NET 现在这么可怜的么?
哦,大概是 Android 开发现在最吃香,哭哭。
duangsuse::Echo
哦,大概是 Android 开发现在最吃香,哭哭。
This media is not supported in your browser
VIEW IN TELEGRAM
现在看来 Swagger 的规范好正规呢,但是如果 GeekAPk API 要拿 Swagger 重写,那不知道要花多少时间呢
duangsuse::Echo
现在看来 Swagger 的规范好正规呢,但是如果 GeekAPk API 要拿 Swagger 重写,那不知道要花多少时间呢
上面提到的 spec,我当时压根没写完,只定义了几个模型
但居然写了 503 行
我的脑子都快 struct 不了这个 YAML 文档了,一大堆二维文法,而且结构又复杂... 🤔
全是竖着的简直淡疼,如果没有 Schema 补齐、可以说 Swagger 这个工具就完全没有用了... (因为写 spec 将花费比现在很多 bootstrap 自动化方案更多的时间...)
(好吧,就是迫真自演 GeekSpec,但是,其实我希望能让它可以扩展一下来兼容 Swagger OpenAPI 3.0 YAML,我真的没有说骄傲什么的,比我牛逼的人很多,不缺一个只能写垃圾程序的 duangsuse
以后 GeekSpec 的更新版本或许会能作为 Swagger OpenAPI 的一种描述方式,也能有一个 OpenAPI 的后端
但居然写了 503 行
我的脑子都快 struct 不了这个 YAML 文档了,一大堆二维文法,而且结构又复杂... 🤔
全是竖着的简直淡疼,如果没有 Schema 补齐、可以说 Swagger 这个工具就完全没有用了... (因为写 spec 将花费比现在很多 bootstrap 自动化方案更多的时间...)
/{username}/token:
get:
tags:
- User
summary: Authorize user
operationId: getToken
parameters:
- name: password
in: query
description: User password
required: true
schema:
type: string
example: sa1tedFi$h
- name: username
in: path
description: User to get new token
schema:
type: string
example: duangsuse
required: true
responses:
200:
description: Got app access token
content:
application/json:
schema:
$ref: '#/components/schemas/AuthToken'
default:
description: Auth failed
content:
application/json:
schema:
$ref: '#/components/schemas/Error'
其实这么复杂的 OpenAPI 3.0 YAML 结构要表示的只是一个最简单最容易理解的定义(指民科的过度设计,但我觉得民科和前端打架还是民科赢 hhhh,实际上都没赢...):type datetime: string = Date我真的不想去学习『如何阅读几乎全是竖排的 YAML』... 所以想来要 GeekApk 利用 Swagger 好像有点难受(迫真
result OK: status = 200
data AuthToken "Authorization token"
= { token: string, expires: datetime }
## Begin API definition
== user
'''
Authorize user
*password: User password
'example_password'
*username: User to get new token
'duangsuse'
>OK: Got app access token
>*: Auth failed
'''
getToken(password: string, username-path: string)
-> (OK) AuthToken
(*) Error
= /:username/token
(好吧,就是迫真自演 GeekSpec,但是,其实我希望能让它可以扩展一下来兼容 Swagger OpenAPI 3.0 YAML,我真的没有说骄傲什么的,比我牛逼的人很多,不缺一个只能写垃圾程序的 duangsuse
以后 GeekSpec 的更新版本或许会能作为 Swagger OpenAPI 的一种描述方式,也能有一个 OpenAPI 的后端
duangsuse::Echo
上面提到的 spec,我当时压根没写完,只定义了几个模型 但居然写了 503 行 我的脑子都快 struct 不了这个 YAML 文档了,一大堆二维文法,而且结构又复杂... 🤔 全是竖着的简直淡疼,如果没有 Schema 补齐、可以说 Swagger 这个工具就完全没有用了... (因为写 spec 将花费比现在很多 bootstrap 自动化方案更多的时间...) /{username}/token: get: tags: - User summary:…
This media is not supported in your browser
VIEW IN TELEGRAM
对类型系统了解不够,还停留在 Java 的幼儿园级别...
其实 GeekSpec 还是蛮工程的,所以什么类型系统实际上就没有,不是那种通常 General-Purpose 意义下的类型系统
考虑一下 GeekSpec 类型的用途,就是标记一种数据类型,这种 HTTP 协议其实都有兼容的...(Content-Type,MIME 类型)
比如说 datetime,可能就是说绑定到原生的某种结构对象,和泛型什么的其实根本没关系(当然泛型也不是什么高级玩意)
其实对于 POSIX C 的 time_t 来说,一个所谓的
其实 GeekSpec 还是蛮工程的,所以什么类型系统实际上就没有,不是那种通常 General-Purpose 意义下的类型系统
考虑一下 GeekSpec 类型的用途,就是标记一种数据类型,这种 HTTP 协议其实都有兼容的...(Content-Type,MIME 类型)
比如说 datetime,可能就是说绑定到原生的某种结构对象,和泛型什么的其实根本没关系(当然泛型也不是什么高级玩意)
其实对于 POSIX C 的 time_t 来说,一个所谓的
datetime 或许可以这么表达?type datetime: string
= (C Linux) time_t
(Ruby) Time
read datetime {
#impl C Linux
return (time_t) atol(str);
#end
#impl Ruby
return Time.at(0, str.to_i, :millisecond)
#end
}
put datetime {
#impl C Linux
size_t size;
char *out;
size = snprinf(out, size, "%l", datetime);
if (size < 0) return NULL;
size++;
out = malloc(size);
if (out == NULL) return NULL;
size = snprintf(out, size, "%l", datetime);
if (size == 0) {
free(out);
return NULL;
}
return out;
#end
#impl Ruby
return sprintf('%i', datetime.tv_sec * 1000 + datetime.tv_usec)
#end
}
validate datetime {
#impl Ruby
str.match? /[0-9]+/
#end
}
路漫漫其修远兮 吾将上下而求索 🤔