矩阵式键盘最小需要多少个IO驱动

1. 概述

        矩阵式键盘由于有其占用硬件资源少的优点有着极其广泛的应用,如PC键盘、电话按键、家用电器等等这类产品.矩阵键盘的基本原理如下所示(仅是原理示例,实际实现上还会为每个按键加上防倒流的二极管解决“鬼影”问题),一般的实现上将每一行和每一列都连接到一个独立的IO上,对行和列进行独立扫描就可以知道那个按键被按下了。

        虽然采用矩阵式键盘可以降低硬件IO的数量,但对于要实现相同数量按键的矩阵键盘最少需要多少个IO驱动呢?需要硬件IO最小其实就是需要满足约束条件x*y=nf_{min}=x+y最小值。

        上述约束条件x*y=n实际上式还存在一些不严谨的地方,这里还有一个隐含条件x、y都需要是整数离散值,若需要实现按键数量n为质数,找到的x,y并不能使x+y值最小(如需要实现按键数量为17,只能找到x=1、y=17使得x+y=18个IO;其实5+4的IO数量就可以实现17个按键),若考虑x、y的整数取值,约束条件应该修改为:

x*y>=n\\ f_{min}=x+y

        当为了简单起见,这里仍然使用约束条件x*y=n,并假定x、y并不一定为整数,再找到x、y后在找到整数的x、y。

2. 何角度

从几何角度看待这个,x*y其实是矩形面积,x+y为矩阵的半周长,如下:

        这时我们就将求x+y的最小值转换成求在面积一定是求周长(半周长)的最小值,直接寻找x+y最小值仍然存在一定的难度,但我们可以反过来考虑,即在周长(a+b)一定情况下,怎么分配a、b长度使得这个矩形面积最大,这个问题就相对比较容易了:当a=b时矩形变成正方形,此时矩形的面积最大周长最短。

3. 微积分角度

        另外也可以从微积分的角度进行分析,首先

f(x)=x+y(x*y=n)

        对y进行代换后:

f(x)=x+\frac{n}{x}

        f(x)的函数图像大概如下(下图将n取值100进行函数图像绘制):

        通过函数图像,大概知道f(x)存在一个最小值,这个f(x)的最小值也是这个f(x)的极值点,对f(x)求导等于0的点为极值点:

f(x)^{-1}=1-\frac{n}{x^2}=0\\ \\ x=\sqrt{n}

        当\sqrt{n}的结果为整数时x+y的最小值为2*\sqrt{n},当\sqrt{n}的结果不为整数时,x,y需要选择接近\sqrt{n}的整数且需要保证x*y>=n

4. 算术-几何平均不等式

        上述无论是面积还是微积分角度都要求x,y为连续值,若为离散的整数,这时x、y需要满足以下等式:

x*y>=n\\ f_{min}=x+y

        这里要要计算x+y的最小值就需要借助数学里面的一个重要的不等式 - 算术-几何平均不等式,对两个正实数存在以下不等式:

\frac{x+y}{2}>=\sqrt{x*y}

        将x于y的约束条件带入上式:

\frac{x+y}{2}>=\sqrt{x*y}>=\sqrt{n}\\ x+y>=2\sqrt{n}

        通过算数-几何不等式可求的x+y的最小值为2\sqrt{n},由于x和y为整数需要对其结果做向上取整。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/868792.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Windows下编译OpenSSL静态库

目录 1. 版本与下载地址 2. 下载与安装VS2015 3. 下载与安装Perl 4. 测试ActivePerl是否安装正确 5. 下载OpenSSL 6. 编译32位OpenSSL静态库 6.1 解压openssl-1.0.2l.tar.gz 6.2 打开VS2015 x86本机工具命令提示符 6.3 输入命令进入到openssl的目录中 6.4 执行配置命…

完美解决AttributeError: ‘DataFrame‘ object has no attribute ‘ix‘的正确解决方法,亲测有效!!!

完美解决AttributeError: ‘DataFrame’ object has no attribute ix’的正确解决方法,亲测有效!!! 亲测有效 完美解决AttributeError: DataFrame object has no attribute ix的正确解决方法,亲测有效!&…

(十五)GLM库对矩阵操作

GLM简单使用 glm是一个开源的对矩阵运算的库&#xff0c;下载地址&#xff1a; https://github.com/g-truc/glm/releases 直接包含其头文件即可使用&#xff1a; #include <glad/glad.h>//glad必须在glfw头文件之前包含 #include <GLFW/glfw3.h> #include <io…

Spring 集成测试指南

在软件开发中&#xff0c;集成测试是一种重要的测试方法&#xff0c;用于验证应用程序各个模块之间的协同工作是否正常。Spring 提供了强大的 Spring Test 模块&#xff0c;以及 MockMvc 工具来进行 HTTP 请求的模拟和验证。本文将介绍如何在 Spring 中进行集成测试&#xff0c…

深入解析ROC曲线及其应用

深入解析ROC曲线及其应用 什么是ROC曲线&#xff1f; ROC曲线&#xff08;Receiver Operating Characteristic Curve&#xff09;&#xff0c;即受试者工作特征曲线&#xff0c;是一种用于评估分类模型性能的工具。它通过展示真阳性率&#xff08;TPR&#xff09;与假阳性率&…

免费制作GIF和实时网络监控工具

ScreenToGif 不允许你们还不知道的一款免费且实用好用的GIF动画制作工具软件。可以实时对区域窗口录制、编辑录制多功能模块&#xff0c;操作简单。 支持自定义增减重复帧数、调整循环播放次数、调整播放速度及删除重复帧。 支持对帧做二次编辑&#xff0c;可进行帧翻转、缩放…

政安晨【零基础玩转各类开源AI项目】基于Ubuntu系统部署ComfyUI:功能最强大、模块化程度最高的Stable Diffusion图形用户界面和后台

目录 ComfyUI的特性介绍 开始安装 做点准备工作 在Conda虚拟环境中进行 依赖项的安装 运行 政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 收录专栏: 零基础玩转各类开源AI项目 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&…

2.1 【入门篇】Cortex M芯片与内核

一,Cortex M芯片简介 Cortex M系列芯片是ARM公司设计的一系列微控制器(MCU),广泛用于嵌入式系统。Cortex M系列芯片主要分为以下几种型号,每种型号都有其独特的特点和应用场景: Cortex-M0和M0+: 特点:这是Cortex M系列中最基本、最低功耗的型号,设计简单,适合成本敏…

昇思训练营打卡第二十天(CycleGAN图像风格迁移互换)

CycleGAN&#xff08;循环生成对抗网络&#xff09;是一种生成对抗网络&#xff08;GAN&#xff09;&#xff0c;它能够在没有成对训练样本的情况下&#xff0c;将一种风格的图片转换成另一种风格。CycleGAN通常用于图像到图像的转换任务&#xff0c;比如将马的图片转换成斑马的…

PHP 高级过滤器

PHP 高级过滤器 PHP 是一种广泛使用的开源服务器端脚本语言,特别适用于网页开发。在处理用户输入和数据交互时,安全性是一个重要的考虑因素。PHP 提供了一套强大的过滤器扩展,用于验证和净化数据。本文将深入探讨 PHP 的高级过滤器功能,包括其使用方法、优势以及在开发中的…

从数字化营销与运营视角:看流量效果的数据分析

基于数据打通的“全链路”营销是当下的“时髦”&#xff0c;应用它的前提是什么&#xff1f;深度营销和运营的关键数据如何获得&#xff1f;如何利用数据进行更精准的营销投放&#xff1f;如何利用数据优化投放的效果&#xff1f;如何促进消费者的转化&#xff0c;以及激活留存…

Java中的多线程并发编程:深入探索与最佳实践

引言 在当今的高性能计算环境中&#xff0c;多线程并发编程成为了软件设计的核心。Java&#xff0c;作为一门成熟且广泛使用的语言&#xff0c;提供了强大的多线程支持。然而&#xff0c;高效地利用这一特性并非易事&#xff0c;它需要对线程的生命周期、同步机制、以及并发工…

IDEA启动tomcat之后控制台出现中文乱码问题

方法1&#xff1a; 第一步&#xff1a;file--setting--Editor--File Encodings 注意页面中全部改为UTF-8&#xff0c;然后apply再ok 第二步&#xff1a;Run--Edit Configuration&#xff0c;将VM options输入以下值&#xff1a; -Dfile.encodingUTF-8 还是一样先apply再ok …

bdeaver mysql忘记localhost密码修改密码添加用户

描述 bdeaver可以连接当前的localhost数据库&#xff0c;但不知道数据库密码是什么。用这个再建一个用户&#xff0c;用来连接数据库 解决 1、在当前的数据库localhost右键&#xff0c;创建-用户 设置这个用户&#xff0c;密码 加权限 2、连接 用新的账号密码去连接&#x…

千古雄文《渔樵问对》原文、译文、解析

邵雍《渔樵问对》&#xff1a;开悟奇文&#xff0c;揭示世界的终极意义 【邵雍《渔樵问对》&#xff1a;开悟奇文&#xff0c;揭示世界的终极意义】 邵雍&#xff08;1011年1月21日&#xff0d;1077年7月27日&#xff0c;宋真宗大中祥符四年十二月二十五日戌时生至神宗熙宁十…

华华给月月出题

题目链接 (a*b)^c (a^c)*(b^c)&#xff0c;我们将合数素数幂分解&#xff0c;然后我们只要处理每个素数的幂&#xff0c;就可以处理出所以合数的幂。 代码&#xff1a; #include<bits/stdc.h> using namespace std; using ll long long; #define fi first #define s…

代谢组数据分析一:代谢组数据准备

介绍 该数据集是来自于Zeybel 2022年发布的文章_Multiomics Analysis Reveals the Impact of Microbiota on Host Metabolism in Hepatic Steatosis_ [@zeybel2022multiomics],它包含了多种组学数据,如: 微生物组(粪便和口腔) 宿主人体学指标 宿主临床学指标 宿主血浆代谢…

SpringCloud Alibaba Sentinel网关流量控制实践总结

官网地址&#xff1a;https://sentinelguard.io/zh-cn/docs/api-gateway-flow-control.html GitHub地址&#xff1a;GitHub Sentinel 网关限流 【1】概述 Sentinel 支持对 Spring Cloud Gateway、Zuul 等主流的 API Gateway 进行限流。 Sentinel 1.6.0 引入了 Sentinel API …

深圳航空x-s3-s4e逆向和顶象滑块动态替换问题

声明(lianxi a15018601872) 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01; 前言(lianxi a…

Hadoop简明教程

文章目录 关于HadoopHadoop拓扑结构Namenode 和 Datanode 基本管理启动Hadoop启动YARN验证Hadoop服务停止Hadoop停止HDFS Hadoop集群搭建步骤准备阶段Java环境配置Hadoop安装与配置HDFS格式化与启动服务测试集群安装额外组件监控与维护&#xff1a; 使用Docker搭建集群使用Hado…