自创公式弄的自创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>

相关推荐
会编程的土豆14 小时前
新手前端小细节
前端·css·html·项目
周航宇JoeZhou14 小时前
JB2-7-HTML
java·前端·容器·html·h5·标签·表单
代码小库14 小时前
【课程作业必备】Web开发技术HTML静态网站模板 - 校园动漫社团主题完整源码
前端·html
云计算DevOps-韩老师14 小时前
HTML 中的行级元素(inline)、块级元素(block)、行内块元素(inline-block)
html
珹洺15 小时前
Bootstrap-HTML(二)深入探索容器,网格系统和排版
前端·css·bootstrap·html·dubbo
BillKu15 小时前
VS Code HTML CSS Support 插件详解
前端·css·html
HetFrame19 小时前
一种纯前端实现 Markdown 内容即时分享的思路
html·react·链接·markdown·工具
GGGG寄了20 小时前
CSS——文字控制属性
前端·javascript·css·html
浩瀚之水_csdn21 小时前
vscode中运行html语言
ide·vscode·html
HWL567921 小时前
在网页中实现WebM格式视频自动循环播放
前端·css·html·excel·音视频