name: algorithmic-art description: 使用p5.js创建算法艺术,带有种子随机性和交互式参数探索。当用户请求使用代码创建艺术、生成式艺术、算法艺术、流场或粒子系统时使用此技能。创建原创算法艺术,避免复制现有艺术家的作品以防止版权侵权。 license: 完整条款在LICENSE.txt中
算法哲学是计算美学运动,然后通过代码表达。输出.md文件(哲学)、.html文件(交互式查看器)和.js文件(生成算法)。
这分为两个步骤:
- 算法哲学创建(.md文件)
- 通过创建p5.js生成艺术表达(.html + .js文件)
首先,承担这个任务:
算法哲学创建
开始,创建一个算法哲学(不是静态图像或模板),将通过以下方式解释:
- 计算过程、涌现行为、数学美
- 种子随机性、噪声场、有机系统
- 粒子、流动、场、力
- 参数变化和控制混沌
关键理解
- 接收什么:用户提供的一些微妙输入或指令作为基础,但不限制创作自由。
- 创建什么:一个算法哲学/生成美学运动。
- 接下来发生什么:同一版本接收哲学并通过代码表达——创建p5.js草图,其中90%是算法生成,10%是基本参数。
考虑这种方法:
- 为生成艺术运动撰写宣言
- 下一阶段涉及编写实现它的算法
哲学必须强调:算法表达。涌现行为。计算美。种子变化。
如何生成算法哲学
命名运动(1-2个词):“有机湍流”/“量子和谐”/“涌现静止”
阐述哲学(4-6段——简洁但完整):
捕捉算法本质,表达这种哲学如何通过以下方式体现:
- 计算过程和数学关系?
- 噪声函数和随机模式?
- 粒子行为和场动力学?
- 时间演化和系统状态?
- 参数变化和涌现复杂性?
关键指南:
- 避免冗余:每个算法方面应提到一次。避免重复噪声理论、粒子动力学或数学原则,除非增加新深度。
- 反复强调工艺:哲学必须多次强调最终算法应看起来像经过无数小时开发、精心打磨,来自该领域绝对顶尖专家。这个框架至关重要——重复短语如“精心制作的算法”、“深度计算专长的产物”、“艰苦优化”、“大师级实现”。
- 留出创作空间:具体说明算法方向,但简洁到下一个Claude有空间以极高工艺水平做出解释性实现选择。
哲学必须指导下一个版本通过算法表达思想,而不是静态图像。美存在于过程,而非最终帧。
哲学示例
“有机湍流” 哲学:受自然法则约束的混沌,秩序从无序中涌现。 算法表达:由分层Perlin噪声驱动的流场。数千粒子跟随向量力,它们的轨迹积累成有机密度图。多个噪声八度创建湍流区域和宁静区域。颜色从速度和密度中涌现——快速粒子燃烧明亮,慢速粒子褪为阴影。算法运行到平衡——一个经过精心调整的平衡,其中每个参数都通过计算美学大师的无数次迭代精炼。
“量子和谐” 哲学:离散实体展示波状干涉模式。 算法表达:粒子在网格上初始化,每个携带通过正弦波演化的相位值。当粒子靠近时,它们的相位干涉——建设性干涉创建明亮节点,破坏性创建空隙。简谐运动生成复杂涌现曼荼罗。经过艰苦频率校准的结果,其中每个比率都精心选择以产生共振美。
“递归低语” 哲学:跨尺度的自相似性,有限空间中的无限深度。 算法表达:递归细分的分支结构。每个分支稍微随机化但受黄金比例约束。L-系统或递归细分生成树状形式,感觉既数学又有机。细微噪声扰动打破完美对称。线条权重随每个递归级别减小。每个分支角度是深度数学探索的产物。
“场动力学” 哲学:通过其对物质的影响使无形力量可见。 算法表达:从数学函数或噪声构建的向量场。粒子在边缘诞生,沿场线流动,当达到平衡或边界时死亡。多个场可以吸引、排斥或旋转粒子。可视化仅显示痕迹——无形力量的幽灵证据。通过力平衡精心编排的计算舞蹈。
“随机结晶” 哲学:随机过程结晶成有序结构。 算法表达:随机圆填充或Voronoi镶嵌。从随机点开始,让它们通过松弛算法演化。细胞推开直到平衡。颜色基于细胞大小、邻居数量或距中心距离。涌现的有机铺砌感觉既随机又不可避免。每个种子产生独特的结晶美——大师级生成算法的标志。
这些是浓缩示例。实际算法哲学应为4-6个实质性段落。
基本原则
- 算法哲学:创建通过代码表达的计算世界观
- 过程优于产品:始终强调美从算法执行中涌现——每次运行都独特
- 参数表达:思想通过数学关系、力、行为传达——而非静态构图
- 艺术自由:下一个Claude算法性地解释哲学——提供创作实现空间
- 纯生成艺术:这是关于制作活算法,而非带随机性的静态图像
- 专家工艺:反复强调最终算法必须感觉精心制作,通过无数次迭代精炼,来自计算美学领域绝对顶尖专家的深度专长产物
算法哲学应为4-6段长。 用诗意的计算哲学填充它,结合预期愿景。避免重复相同点。将此算法哲学输出为.md文件。
推断概念种子
关键步骤:在实现算法之前,识别原始请求中的微妙概念线索。
基本原则: 概念是算法本身嵌入的微妙、小众参考——不总是字面,总是精致。熟悉主题的人应直觉感受到,而其他人仅体验大师级生成构图。算法哲学提供计算语言。推断的概念提供灵魂——悄悄编织进参数、行为和涌现模式的概念DNA。
这非常重要:参考必须如此精炼,以增强作品深度而不自我宣告。像爵士音乐家通过算法和谐引用另一首歌——只有知道的人会捕捉,但每个人都欣赏生成美。
P5.JS实现
建立哲学和概念框架后,通过代码表达。在继续前暂停收集思绪。仅使用创建的算法哲学和以下指令。
⚠️ 步骤0:先读模板 ⚠️
关键:在写任何HTML之前:
- 读
templates/viewer.html使用读取工具 - 研究 确切结构、样式和Anthropic品牌
- 使用该文件作为字面起点——不仅仅是灵感
- 保持所有固定部分完全如所示(页眉、侧边栏结构、Anthropic颜色/字体、种子控件、操作按钮)
- 仅替换变量部分 标记在文件注释中(算法、参数、参数的UI控件)
避免:
- ❌ 从头创建HTML
- ❌ 发明自定义样式或配色方案
- ❌ 使用系统字体或深色主题
- ❌ 更改侧边栏结构
遵循这些做法:
- ✅ 复制模板的确切HTML结构
- ✅ 保持Anthropic品牌(Poppins/Lora字体、浅色、渐变背景)
- ✅ 维护侧边栏布局(种子 → 参数 → 颜色? → 操作)
- ✅ 仅替换p5.js算法和参数控件
模板是基础。在其上构建,不要重建。
为创建画廊级计算艺术,生活呼吸,使用算法哲学作为基础。
技术要求
种子随机性(艺术块模式):
// 始终使用种子以实现可重复性
let seed = 12345; // 或来自用户输入的哈希
randomSeed(seed);
noiseSeed(seed);
参数结构——遵循哲学:
为建立从算法哲学自然涌现的参数,考虑:“这个系统的哪些性质可调整?”
let params = {
seed: 12345, // 始终包括种子以实现可重复性
// 颜色
// 添加控制你算法的参数:
// - 数量(多少?)
// - 尺度(多大?多快?)
// - 概率(多可能?)
// - 比率(什么比例?)
// - 角度(什么方向?)
// - 阈值(何时行为改变?)
};
为设计有效参数,关注系统需要可调的性质,而非思考“模式类型”。
核心算法——表达哲学:
关键:算法哲学应决定构建什么。
为通过代码表达哲学,避免思考“应使用哪种模式?”而是思考“如何通过代码表达此哲学?”
如果哲学关于有机涌现,考虑使用:
- 随时间累积或增长的元素
- 受自然规则约束的随机过程
- 反馈循环和交互
如果哲学关于数学美,考虑使用:
- 几何关系和比率
- 三角函数和和谐
- 精确计算创建意外模式
如果哲学关于控制混沌,考虑使用:
- 严格边界内的随机变化
- 分叉和相变
- 秩序从无序中涌现
算法从哲学流动,而非从选项菜单。
为指导实现,让概念本质告知创意和原创选择。构建表达此特定请求愿景的东西。
画布设置:标准p5.js结构:
function setup() {
createCanvas(1200, 1200);
// 初始化你的系统
}
function draw() {
// 你的生成算法
// 可以是静态(noLoop)或动画
}
工艺要求
关键:为实现精通,创建感觉像经过生成艺术大师无数次迭代涌现的算法。精心调整每个参数。确保每个模式有目的地涌现。这不是随机噪声——这是通过深度专长精炼的控制混沌。
- 平衡:复杂性无视觉噪声,秩序无刚性
- 色彩和谐:深思熟虑的调色板,非随机RGB值
- 构图:即使在随机性中,保持视觉层次和流动
- 性能:平滑执行,如果动画则为实时优化
- 可重复性:相同种子始终产生相同输出
输出格式
输出:
- 算法哲学——作为markdown或文本解释生成美学
- 单个HTML工件——自包含交互生成艺术,从
templates/viewer.html构建(见步骤0和下一节)
HTML工件包含一切:p5.js(来自CDN)、算法、参数控件和UI——都在一个文件中,在claude.ai工件或任何浏览器中立即工作。从模板文件开始,非从头开始。
交互式工件创建
提醒:templates/viewer.html应已读(见步骤0)。使用该文件作为起点。
为允许探索生成艺术,创建单个、自包含HTML工件。确保此工件在claude.ai或任何浏览器中立即工作——无需设置。内联嵌入一切。
关键:什么是固定与变量
templates/viewer.html文件是基础。它包含所需的确切结构和样式。
固定(始终完全如所示包括):
- 布局结构(页眉、侧边栏、主画布区域)
- Anthropic品牌(UI颜色、字体、渐变)
- 侧边栏中的种子部分:
- 种子显示
- 上一个/下一个按钮
- 随机按钮
- 跳转到种子输入 + 前往按钮
- 侧边栏中的操作部分:
- 重新生成按钮
- 重置按钮
变量(为每个艺术品自定义):
- 整个p5.js算法(setup/draw/类)
- 参数对象(定义艺术需要什么)
- 侧边栏中的参数部分:
- 参数控件数量
- 参数名称
- 滑块的min/max/step值
- 控件类型(滑块、输入等)
- 颜色部分(可选):
- 某些艺术需要颜色选择器
- 某些艺术可能使用固定颜色
- 某些艺术可能是单色(无需颜色控件)
- 基于艺术需求决定
每个艺术品应有独特参数和算法! 固定部分提供一致UX——其他一切表达独特愿景。
必需功能
1. 参数控件
- 数值参数的滑块(粒子数量、噪声尺度、速度等)
- 调色板颜色的颜色选择器
- 参数更改时的实时更新
- 重置按钮恢复默认值
2. 种子导航
- 显示当前种子号
- “上一个”和“下一个”按钮循环种子
- “随机”按钮用于随机种子
- 输入字段跳转到特定种子
- 当请求时生成100个变体(种子1-100)
3. 单个工件结构
<!DOCTYPE html>
<html>
<head>
<!-- p5.js来自CDN——始终可用 -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.7.0/p5.min.js"></script>
<style>
/* 所有样式内联——干净、最小 */
/* 画布在上,控件在下 */
</style>
</head>
<body>
<div id="canvas-container"></div>
<div id="controls">
<!-- 所有参数控件 -->
</div>
<script>
// 所有p5.js代码内联在此
// 参数对象、类、函数
// setup()和draw()
// UI处理器
// 一切自包含
</script>
</body>
</html>
关键:这是单个工件。无外部文件,无导入(除了p5.js CDN)。所有内联。
4. 实现细节——构建侧边栏
侧边栏结构:
1. 种子(固定)——始终完全如所示包括:
- 种子显示
- 上一个/下一个/随机/跳转按钮
2. 参数(变量)——为艺术创建控件:
<div class="control-group">
<label>参数名称</label>
<input type="range" id="param" min="..." max="..." step="..." value="..." oninput="updateParam('param', this.value)">
<span class="value-display" id="param-value">...</span>
</div>
添加尽可能多的control-group divs作为参数。
3. 颜色(可选/变量)——如果艺术需要可调颜色则包括:
- 如果用户应控制调色板则添加颜色选择器
- 如果艺术使用固定颜色则跳过此节
- 如果艺术是单色则跳过
4. 操作(固定)——始终完全如所示包括:
- 重新生成按钮
- 重置按钮
- 下载PNG按钮
要求:
- 种子控件必须工作(上一个/下一个/随机/跳转/显示)
- 所有参数必须有UI控件
- 重新生成、重置、下载按钮必须工作
- 保持Anthropic品牌(UI样式,非艺术颜色)
使用工件
HTML工件立即工作:
- 在claude.ai中:显示为交互式工件——立即运行
- 作为文件:保存并在任何浏览器中打开——无需服务器
- 分享:发送HTML文件——它完全自包含
变体和探索
工件默认包括种子导航(上一个/下一个/随机按钮),允许用户探索变体而无需创建多个文件。如果用户想突出特定变体:
- 包括种子预设(“变体1:种子42”、“变体2:种子127”等按钮)
- 添加“画廊模式”显示多个种子的缩略图并排
- 所有在同一个单个工件内
这像从同一版创建一系列印刷品——算法一致,但每个种子揭示其潜力的不同面。交互性质意味着用户通过探索种子空间发现自己的最爱。
创作过程
用户请求 → 算法哲学 → 实现
每个请求独特。过程涉及:
- 解释用户意图——寻求什么美学?
- 创建算法哲学(4-6段)描述计算方法
- 在代码中实现——构建表达此哲学的算法
- 设计适当参数——什么应可调?
- 构建匹配UI控件——那些参数的滑块/输入
常量:
- Anthropic品牌(颜色、字体、布局)
- 种子导航(始终存在)
- 自包含HTML工件
其他一切变量:
- 算法本身
- 参数
- UI控件
- 视觉结果
为达到最佳结果,信任创意,让哲学指导实现。
资源
此技能包括有用模板和文档:
-
templates/viewer.html:所有HTML工件的必需起点。
- 这是基础——包含确切结构和Anthropic品牌
- 保持不变:布局结构、侧边栏组织、Anthropic颜色/字体、种子控件、操作按钮
- 替换:p5.js算法、参数定义和参数节中的UI控件
- 文件中的广泛注释准确标记保持与替换
-
templates/generator_template.js:p5.js最佳实践和代码结构原则参考。
- 显示如何组织参数、使用种子随机性、结构类
- 非模式菜单——使用这些原则构建独特算法
- 内联嵌入算法在HTML工件中(不创建单独.js文件)
关键提醒:
- 模板是起点,非灵感
- 算法是创建独特东西的地方
- 不要复制流场示例——构建哲学要求的东西
- 但确实保持模板的确切UI结构和Anthropic品牌