自创公式弄的自创AⅠ

<!DOCTYPE html>

<html lang="zh-CN">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width,initial-scale=1.0">

<title>意义密度问答</title>

<style>body{font-family:Arial,sans-serif;max-width:800px;margin:20px auto;padding:0 20px;}.g{margin:15px 0;}label{display:block;margin-bottom:5px;font-weight:bold;}input,textarea{width:100%;padding:8px;box-sizing:border-box;border:1px solid #ccc;border-radius:4px;}textarea{height:80px;resize:vertical;}button{padding:10px 15px;margin:5px;border:none;border-radius:4px;background:#007bff;color:#fff;cursor:pointer;}button:hover{background:#0056b3;}#r,#kb{margin-top:20px;padding:10px;border:1px solid #ccc;border-radius:4px;}</style>

</head>

<body>

<h1>意义密度神经网络问答</h1>

<div class="g"><label for="q">问题</label><input type="text" id="q" placeholder="输入问题..."></div>

<div class="g"><label for="ans">回答(英文逗号分隔)</label><textarea id="ans" placeholder="多个回答用英文逗号分隔..."></textarea></div>

<div class="g"><label for="nq">新问题查询</label><input type="text" id="nq" placeholder="输入查询问题..."></div>

<button onclick="updKB()">添加到知识库</button>

<button onclick="qry()">查询答案</button>

<button onclick="rst()">重置所有</button>

<div id="r">等待查询...</div>

<div id="kb"><strong>知识库:</strong> 暂无数据</div>

<script>

const A=0.5,B=2.0;let kb=[];

function t2h(t){let h=0,p=31;for(let i=0;i<t.length;i++)h=(h*p+t.charCodeAt(i))&0xFFFFFFFF;return h;}

function sim(t1,t2){

if(!t1||!t2)return 0;

const h1=t2h(t1),h2=t2h(t2);

const hs=1-Math.abs(h1-h2)/(Math.max(h1,h2)||1);

const m1=t1.split('').reduce((s,c)=>s+c.charCodeAt(0),0)/t1.length;

const m2=t2.split('').reduce((s,c)=>s+c.charCodeAt(0),0)/t2.length;

const cs=1-Math.abs(m1-m2)/(Math.max(m1,m2)||1);

return 0.6*hs+0.4*cs;

}

function sss(aL){

let s=0;aL.forEach(a=>{

const d=1-sim(aL[0],a);

const l=a.length/10;s+=d*l;

});return s;

}

function tcr(d,tm,ss,s){return A*(tm/ss)+d*(1+d/B)-s;}

function rndKB(){

const kbe=document.getElementById('kb');

if(!kb.length){kbe.innerHTML="<strong>知识库:</strong> 暂无数据";return;}

let h="<strong>知识库:</strong><br>";

kb.forEach((i,idx)=>h+=`{idx+1}. 问题: {i.q}<br>&nbsp;&nbsp;回答: [{i.a.join(', ')}\]\\ \ 意义密度: {i.md.toFixed(4)}<br><br>`);

kbe.innerHTML=h;

}

function updKB(){

const q=document.getElementById('q').value.trim(),aL=document.getElementById('ans').value.trim().split(',').map(a=>a.trim());

if(!q||!aL.length){document.getElementById('r').textContent="请输入完整内容!";return;}

kb.push({q:q,a:aL,md:sim(q,q)});

rndKB();document.getElementById('r').textContent="添加成功!";

document.getElementById('q').value=document.getElementById('ans').value="";

}

function qry(){

const q=document.getElementById('nq').value.trim();let r=document.getElementById('r');

if(!q||!kb.length){r.textContent="请输入查询问题并确保知识库有数据!";return;}

let ba="",mr=-Infinity,bq="";

kb.forEach(i=>{

const s=sim(q,i.q);

const tm=s*i.md,ss=i.a.length,sSum=sss(i.a);

i.a.forEach(a=>{

const d=sim(q,a);const rt=tcr(d,tm,ss,sSum);

if(rt>mr){mr=rt;ba=a;bq=i.q;}

});

i.md=(i.md+s)/2;

});

r.innerHTML=`"<strong>匹配问题:</strong> {bq}\\最优回答:\ {ba}<br><strong>总变化率:</strong> ${mr.toFixed(4)}`;

rndKB();

}

function rst(){

kb=[];document.getElementById('q').value=document.getElementById('ans').value=document.getElementById('nq').value="";

document.getElementById('r').textContent="等待查询...";rndKB();

}

</script>

</body>

</html>

相关推荐
自然 醒9 小时前
uni-app开发微信小程序,如何使用towxml去渲染md格式和html标签格式的内容?
微信小程序·uni-app·html
我命由我1234511 小时前
React - 组件优化、children props 与 render props、错误边界
前端·javascript·react.js·前端框架·html·ecmascript·js
李宏伟~11 小时前
大文件分片案例html + nodejs + 视频上传案例
javascript·html·音视频
ZC跨境爬虫12 小时前
海南大学交友平台登录页开发实战day3(解决python传输并读取登录信息的问题)
前端·数据库·python·html
E_ICEBLUE12 小时前
Python 办公自动化:快速将 HTML 转换为 PDF 格式
python·pdf·html
PieroPc2 天前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
sayamber2 天前
Nginx + Docker部署个人博客,从零到上线完整教程(2026最新版)
html
榴莲omega2 天前
第12天:CSS(一)| Flexbox 布局完全指南
前端·css·html·js八股
fqrj20262 天前
企业官网如何设计?专业公司网站设计制作要点解析
css·html·网站建设·网站开发
阿捞22 天前
在 .NET 中使用 Moonshot Kimi + AgentFramework:从 SDK 到 Agent 的完整实践
html·.net·xhtml