1 Star 0 Fork 0

邓适存/entropy

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
entropy.js 1.54 KB
一键复制 编辑 原始数据 按行查看 历史
邓适存 提交于 2024-10-06 16:08 . feat:作业提交
const readlineSync = require('readline-sync');
// 计算信源熵的函数
function calculateEntropy(probabilities) {
let entropy = 0;
for (let p of probabilities) {
if (p > 0) {
entropy -= p * Math.log2(p); // 计算熵的公式
}
}
return entropy;
}
// 解析输入并进行验证的函数
function parseInput(input) {
let probabilities = input.split(/[, ]+/).map(Number); // 支持空格或逗号分隔
let sum = probabilities.reduce((a, b) => a + b, 0);
// 验证输入是否合法
if (probabilities.some(isNaN)) {
console.error("输入无效!请输入有效的数字。");
process.exit(1);
}
if (probabilities.some(p => p < 0 || p > 1)) {
console.error("概率必须在 0 和 1 之间!");
process.exit(1);
}
if (sum !== 1) {
console.error("概率总和必须为 1!");
process.exit(1);
}
return probabilities;
}
// 获取用户输入的概率分布
function getUserInput() {
console.log("请输入信源概率分布: (Ctrl+D 退出输入)");
let input = readlineSync.question();
return parseInput(input);
}
// 主程序逻辑
function main() {
let probabilities;
if (process.argv.length > 2) {
const input = process.argv.slice(2).join(' ');
probabilities = parseInput(input);
} else {
probabilities = getUserInput();
}
console.log(`p = [${probabilities.join(',')}]`);
console.log(`h(p) = ${calculateEntropy(probabilities).toFixed(3)} bit`);
}
// 运行程序
main();
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
NodeJS
1
https://gitee.com/dengdoris/entropy.git
git@gitee.com:dengdoris/entropy.git
dengdoris
entropy
entropy
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385