将 SPM 依赖从 mlx-swift-examples 2.29.1 迁到改名延续仓库 mlx-swift-lm 2.31.3(含 qwen3_5 架构、旧 loadContainer API 兼容),文本 LLM 由 Qwen3-1.7B 换为 Qwen3.5-2B-4bit(走 qwen3_5→Qwen35Model 文本路径)。 连带 mlx-swift 0.29.1→0.31.4,顺修弃用 API: - MLX.GPU.clearCache() → MLX.Memory.clearCache() - MLX.GPU.set(cacheLimit:) → MLX.Memory.cacheLimit 更新 ModelManifest(.llm 文件清单+精确字节数,~1.63GiB)、ModelManifestTests、 HealthExport.modelTag 默认值。App BUILD SUCCEEDED + ModelManifestTests 通过。 保留作 MNN 改造的 GPU 兜底基线。 Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
73 lines
2.7 KiB
Swift
73 lines
2.7 KiB
Swift
import Foundation
|
|
import SwiftData
|
|
|
|
/// 「导出身体档案」单条历史。一次成功生成 = 一条 HealthExport。
|
|
///
|
|
/// 与 Indicator/Report 等源记录之间用 `[String]` 弱关联(而不是 SwiftData
|
|
/// 关系),这样源记录被永久删除时,历史导出仍保留为快照。
|
|
///
|
|
/// 属性写法与项目其他 @Model(Indicator/ChatTurn 等)对齐:
|
|
/// 不在属性上写 default,所有默认值都在 `init` 里。
|
|
@Model
|
|
final class HealthExport {
|
|
var prompt: String
|
|
var content: String
|
|
var createdAt: Date
|
|
|
|
// 引用回链(§3.3 RAG 引用,W3 再做点击跳转)
|
|
var referencedIndicatorIDs: [String]
|
|
var referencedReportIDs: [String]
|
|
var referencedSymptomIDs: [String]
|
|
var referencedDiaryIDs: [String]
|
|
|
|
// 意图抽取快照,供「重新生成」复用,不再二次抽意图
|
|
var inferredTimeFromDate: Date?
|
|
var inferredTimeToDate: Date?
|
|
var inferredIntent: String?
|
|
/// 意图的中文标签(如「感冒就诊」),供「我的导出」列表 badge 展示;可选,旧库走轻量迁移。
|
|
var inferredLabelCN: String?
|
|
|
|
// demo 卖点凭证
|
|
/// 模型 tag,如 "Qwen3.5-2B-4bit"。截图能证明本地推理。
|
|
var modelTag: String
|
|
/// 末次 tok/s,对应 demo 卖点 #6 Live Activity 数据。
|
|
var decodeRate: Double
|
|
|
|
init(prompt: String = "",
|
|
content: String = "",
|
|
createdAt: Date = .now,
|
|
referencedIndicatorIDs: [String] = [],
|
|
referencedReportIDs: [String] = [],
|
|
referencedSymptomIDs: [String] = [],
|
|
referencedDiaryIDs: [String] = [],
|
|
inferredTimeFromDate: Date? = nil,
|
|
inferredTimeToDate: Date? = nil,
|
|
inferredIntent: String? = nil,
|
|
inferredLabelCN: String? = nil,
|
|
modelTag: String = "Qwen3.5-2B-4bit",
|
|
decodeRate: Double = 0) {
|
|
self.prompt = prompt
|
|
self.content = content
|
|
self.createdAt = createdAt
|
|
self.referencedIndicatorIDs = referencedIndicatorIDs
|
|
self.referencedReportIDs = referencedReportIDs
|
|
self.referencedSymptomIDs = referencedSymptomIDs
|
|
self.referencedDiaryIDs = referencedDiaryIDs
|
|
self.inferredTimeFromDate = inferredTimeFromDate
|
|
self.inferredTimeToDate = inferredTimeToDate
|
|
self.inferredIntent = inferredIntent
|
|
self.inferredLabelCN = inferredLabelCN
|
|
self.modelTag = modelTag
|
|
self.decodeRate = decodeRate
|
|
}
|
|
}
|
|
|
|
extension HealthExport {
|
|
/// 列表 / strip 显示的 prompt 摘要(≤ 30 字 + ...)
|
|
var promptPreview: String {
|
|
let trimmed = prompt.trimmingCharacters(in: .whitespacesAndNewlines)
|
|
if trimmed.count <= 30 { return trimmed }
|
|
return trimmed.prefix(30) + "…"
|
|
}
|
|
}
|