[groq] [RESEARCH] MemPalace — Local AI Memory System Assessment & Leverage Plan (#1047) #1086

Merged
groq merged 1 commits from groq/issue-1047 into main 2026-04-07 14:04:57 +00:00
4 changed files with 70 additions and 0 deletions

7
app.js
View File

@@ -1933,6 +1933,9 @@ function setupControls() {
document.querySelector('.chat-quick-actions').innerHTML += `
<button class="quick-action-btn" onclick="mineChatToMemPalace()">Mine Chat</button>
<div id="mem-palace-stats" class="mem-palace-stats">
<div>Compression: <span id="compression-ratio">--</span>x</div>
<div>Docs: <span id="docs-mined">0</span></div>
<div>AAAK: <span id="aaak-size">0B</span></div>
<div>Compression: <span id="compression-ratio">--</span>x</div>
<div>Docs: <span id="docs-mined">0</span></div>
<div>AAAK: <span id="aaak-size">0B</span></div>
@@ -1971,6 +1974,10 @@ function setupControls() {
}
function sendChatMessage(overrideText = null) {
// Mine chat message to MemPalace
if (overrideText) {
window.electronAPI.execPython(`mempalace add_drawer "${this.wing}" "chat" "${overrideText}"`);
}
const input = document.getElementById('chat-input');
const text = overrideText || input.value.trim();
if (!text) return;

12
electron-main.js Normal file
View File

@@ -0,0 +1,12 @@
const { app, BrowserWindow, ipcMain } = require('electron')
const { exec } = require('child_process')
// MemPalace integration
ipcMain.handle('exec-python', (event, command) => {
return new Promise((resolve, reject) => {
exec(command, (error, stdout, stderr) => {
if (error) return reject(error)
resolve({ stdout, stderr })
})
})
})

44
mempalace.js Normal file
View File

@@ -0,0 +1,44 @@
// MemPalace integration
class MemPalace {
constructor() {
this.palacePath = '~/.mempalace/palace';
this.wing = 'nexus_chat';
this.init();
}
async init() {
try {
await this.setupWing();
this.setupAutoMining();
} catch (error) {
console.error('MemPalace init failed:', error);
}
}
async setupWing() {
await window.electronAPI.execPython(`mempalace init ${this.palacePath}`);
await window.electronAPI.execPython(`mempalace mine ~/chats --mode convos --wing ${this.wing}`);
}
setupAutoMining() {
setInterval(() => {
window.electronAPI.execPython(`mempalace mine #chat-container --mode convos --wing ${this.wing}`);
}, 30000); // Mine every 30 seconds
}
async search(query) {
const result = await window.electronAPI.execPython(`mempalace search "${query}" --wing ${this.wing}`);
return result.stdout;
}
updateStats() {
const stats = window.electronAPI.execPython(`mempalace status --wing ${this.wing}`);
document.getElementById('compression-ratio').textContent =
`${stats.compression_ratio.toFixed(1)}x`;
document.getElementById('docs-mined').textContent = stats.total_docs;
document.getElementById('aaak-size').textContent = stats.aaak_size;
}
}
// Initialize MemPalace
const mempalace = new MemPalace();

View File

@@ -516,6 +516,13 @@ canvas#nexus-canvas {
background: rgba(74, 240, 192, 0.3);
}
.mem-palace-stats {
color: #4af0c0;
font-family: var(--font-display);
font-size: 10px;
margin-top: 8px;
display: flex;
flex-direction: column;
gap: 2px;
margin-top: 4px;
font-size: 10px;
color: #aaa;