思源与渐进写作相关的问题

本贴最后更新于 246 天前,其中的信息可能已经斗转星移

本文是《渐进写作尝试(暂定名)》中的部分内容,因采取渐进写作故完成日期未知,听说思源最近在改闪卡,并且社区里也有一点和渐进写作相关的讨论,便先分享出来,抛砖引玉

思源有着文档型双链笔记软件里最好的写作体验,并且也有间隔重复功能,但有一些问题

思源的间隔重复功能叫闪卡,使用的是 FSRS 算法,FSRS 是单纯针对问答卡的算法,使用问答评分的形式计算间隔,并没有对文章卡/摘录卡的支持

就算强行使用效果也并不好,新卡前几个选项都是当天就能再刷到,最后一个选项直接扔六天后了。对于问答卡而言,当天反复复习可能并没有什么问题;但文章卡,不论是从文章中摘录、对摘录挖空、还是写作,一天最多推一次就够了。六天起步又太久了

尽管 FSRS 并不是为渐进阅读设计的,不支持文章卡,但在使用中进行渐进阅读也并不是无法接受,因为文章卡总会被处理为问答卡,最后就可以应用上 FSRS。但对于渐进写作,文章卡本身就是目的,是终点,强行使用的适用性低到无法接受是十分正常的

或许可以通过调整参数来提升可用性,但这就不是普通用户能做到的事情了

思源里想为渐进写作文档添加间隔重复也有些麻烦,如果是一个分了很多细致标题的文档,需要为每一个标题添加间隔重复(这样才称得上渐进)。另一个问题是,上级标题会包含下级标题,可能我只是在上级标题下写一些描述,细则丢给几个下级标题,但在间隔重复到上级标题时,也会看到下级的内容。也就是说文章卡的范围是不完全可控的,这只能通过将所有文本内容细分到最末层的标题来避免,例如专门建一个“描述”标题在下面写描述

思源目前的间隔重复页面只能看到卡片的内容,看不到目录树/大纲树和反链面板,在渐进写作中只有面包屑是不够的,有时需要看到整篇文章的结构;反链面板则对于在双链笔记中的写作十分重要,不过这也可以通过插件在文章末尾里添加反链面板来解决。另外反链面板是标题的反链,而不是整个文档的反链,记录的时候可能不会链得那么细,这也是个问题

总体来说思源距离顺畅地渐进写作还有着不小的距离,一些是需要思源本身对这个方向进行的改进,还有一些是受到 FSRS 只支持问答卡的限制,这方面可能会更加艰难

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    22023 引用 • 87833 回帖 • 3 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • Grrittyb 1

    我其实一直有一个疑惑,supermemo 在「渐进阅读」方面算是做的最好的了,然而 supermemo 的 「摘录卡片」其实并没有评分选项,它只是用来排期的。你今天复习了的结果并不影响它下次出现的时间。

    但是现在大家貌似普遍都用 FSRS 来调度「摘录卡片」(或者是文章卡),但是除了增加迷惑性之外并没有任何作用。FSRS 本身是「间隔重复记忆算法」而不是「渐进阅读算法」。

    完全的随机漫游都算是比较合理的「渐进阅读」的调度了...至少它没有那么多无意义的评分,心智负担也会小很多。

    我个人认为 思源的渐进阅读插件,通过「优先级」去调度「摘录卡片」是比较有效的。在随机漫游的基础上增加「优先级」权重来实现「渐进阅读」而不是通过「卡片评价」。

    1 回复
  • fwzuw
    作者

    sm 的卡片会在创建时计算一个出 A-因子,这个值会影响卡片复习间隔增大的程度,值越高间隔增加的也就越快

    在问答卡中,这个值会随着评分更新,记得好就变大,记得差就变小,并且不能手动修改。当然影响复习排期的还有其他东西

    而在文章卡中,这个值可以手动修改,如果不修改的话,那么就一直是创建这张卡时的值。至于有没有别的东西影响排期我就不知道了

    至于创建卡时是怎么计算这个值的,并不怎么清楚,可能涉及到字数、摘录次数、卡片层级、继承等

    优先级主要影响卡片在复习队列中的位置,对于排期的影响只会在自动推迟时产生,当之前的卡没刷完时,优先级高的少推迟几天,优先级低的多推迟几天

    鉴于 FSRS 不支持文章卡,对文章卡的排期算法实现将会是实现渐进阅读与渐进写作以及所有涉及文章卡的进阶技术时最头疼的地方

    1 回复
  • Grrittyb

    这个是 sm-2 的算法吧。后续的算法可能已经相差比较大了。

    其实目前来说,对于问答卡算法的最优解还是 FSRS,使用自己的历史复习记录拟合后的参数,记忆保留率超过了 sm-17。只是目前的思源笔记,想要优化参数还比较困难。一是,需要依赖第三方插件导出复习记录。二是,没有多个参数配置,因为对于难度不同的一组问答卡,参数会有不同。

    对于文章卡的渐进阅读,首先并不清楚 supermemo 是如何处理的,因为没有开源。想要模仿也不是短期能做到的事情。我个人倾向的方案是,手动筛选进行学习。通过 渐进阅读 插件(当然目前还有些小问题)实现简单的「增量阅读」。

    sm 通过算法去推文章很好,在不同的文章中随机渐进。但是,如果想要系统性的学习,由算法安排阅读可能不是一件好事,我对它的「效率」存疑(这是说的是「效率」,而不是「乐趣」)。

    实际上,知识的记忆完全可以依托于「问答卡」,而「文章卡」的调度,仅仅只是自己当前「阅读偏好」的体现。甚至是,在现代社会,很多时候由于「外在压力」,我们需要自己选择「文章卡」进行渐进,而不是「算法」选择。从这个层面来说,可能自主选择的「渐进阅读」稳定性会更好些(也算是在现代社会进行学习的一种妥协,我们很难达到最优解)

    sm 最终的意义是「学习」,所有的东西都是辅助我们降低学习阻力。但是每个人有不同的外部环境。woz 显然不是从一个外界变化复杂的、需要面临各种生存压力的普通人角度考虑的。对于个人的学习,还是应该适当调整。

    1 回复
  • fwzuw
    作者

    我描述的是 sm 18 中的行为,自然是 sm-18 算法

    你可能没有用过 sm,所以有一个误解,那就是只能由算法推送文章来决定阅读时机。实际上还有两种选择,一是将材料导入后设为新材料,新材料不会排期,需要自己主动切换到新材料队列阅读,阅读过的卡才会进入排期(前提是你没有将他忽略或 done);二是直接在目录树里点开读,毕竟卡片和目录就在那里,没人不让你读。你可能会疑惑我在队列外读完了,那队列里的怎么办呢?如果你读完了,直接忽略或者 done 就行了,就不会再排期了

    并不是说 sm 可以用算法推送文章来初次阅读就一定要这么做,实际上大部分材料都只适合线性阅读,因为他们都是为线性阅读而写的,一定要分割后乱序阅读往往会很吃力,而且还有别的问题

    以上是对于不能手动选择阅读材料的误解澄清,你是可以主动阅读的

    可能是我之前的回复中的“文章卡”让你产生了误会,实际上那里指的是 渐进阅读中的摘录卡 与 渐进写作中的文章卡,并不是在强调 渐进阅读中的文章卡

    1 回复
    1 操作
    fwzuw 在 2024-03-05 00:42:04 更新了该回帖
  • Grrittyb

    使用过一段时间的 sm,其实很少选择手动去处理。sm 文档树管理比较困难。导入多了后其实不太方便排序,加上 sm 的摘录卡增加了很多无意义的碎片。我个人到后面就很少直接摘录了。而是直接创建新卡比较多,即使这样,文档树管理还是麻烦。这是 sm 的问题,这里暂且不讨论。

    我刚刚的回复,其实主要想法是:不去模拟 sm 的算法,也不使用 fsrs,而是暂且先试用简单的 随机漫步 + 优先级推荐 + 自由选择 进行渐进阅读、渐进写作。这样对于大多数人还是适用的。

推荐标签 标签

  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖 • 1 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 52 关注
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 47 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    197 引用 • 547 回帖
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 1 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    107 引用 • 153 回帖 • 3 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    28 引用 • 108 回帖
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    5 引用 • 26 回帖 • 526 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2388 回帖
  • 分享

    有什么新发现就分享给大家吧!

    247 引用 • 1792 回帖 • 7 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 32 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 1 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 1 关注
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 622 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • gRpc
    11 引用 • 9 回帖 • 61 关注
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 388 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 584 关注
  • OpenShift

    红帽提供的 PaaS 云,支持多种编程语言,为开发人员提供了更为灵活的框架、存储选择。

    14 引用 • 20 回帖 • 624 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 621 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    334 引用 • 323 回帖
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 124 关注