- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有常数 A、B、C 和 N,我想弄清楚如何“混合”A、B 和 C 的数量以创建 N 的平均值。
在公式中,它看起来像这样:
(xA + yB + zC)/(x+y+z) = N
我如何计算出 x、y、z 的值?
编辑:我不是在寻找一个有限的解决方案,我在寻找一个最适合的算法,它将返回 x、y 和 z 之和的最低值。
最佳答案
我觉得你的问题很有道理。处理此类问题的一种方法是寻找最小长度的解决方案(p1,p2,p3)
。这样做有一个明确的程序,它会给出一个明确的、单一的结果。假设我们的系统是
|A B C| |p1| |N|
|1 1 1| |p2| = |1|
|p3|
其中p1, p2, p3
是混合中A, B, C
的三个权重。我们可以将这三个矩阵命名如下
|A B C| |p1| |N|
M = |1 1 1|, x = |p2|, y = |1|
|p3|
然后构造M的伪逆,求解方程如下:
x = M^T (M M^T)^{-1} y
向量 x
然后求解系统,并且是求解该方程组的最小长度向量。上面的方程可以通过拉格朗日乘数计算得到,但你不需要知道它就可以使用它。
在你的情况下,我手工计算了一点难度,并得到了解决方案
p1 = ( (3*A-S)*N - A*S+T ) / ( (A-B)^2 + (B-C)^2 + (C-A)^2 )
p2 = ( (3*B-S)*N - B*S+T ) / ( (A-B)^2 + (B-C)^2 + (C-A)^2 )
p3 = ( (3*C-S)*N - C*S+T ) / ( (A-B)^2 + (B-C)^2 + (C-A)^2 )
其中 S=A+B+C
和 T=A^2+B^2+C^2
。您可以检查它是否满足您问题的所有要求,并且可以与其他解决方案进行比较以了解我的解决方案是最小的。请参阅下面的 Java 实现,它在命令行上获取 A、B、C 和 N,并以百分比形式打印出最佳混合物的权重。请注意,接近极端(当 N
接近 min(A,B,C)
或 max(A,B,C)
时)伪逆法给出负权重。在这种情况下,您应该将相应的权重设置为 0,并使用标准线性代数技术计算其他两个变量。如果 N
超出从 min(A,B,C)
到 max(A,B,C)
的区间,则不可能得到一个非负的混合,所以实现打印出一个负权重的答案。
一般来说,如果您有矩阵库,计算会快速而直接。有关更多信息,请搜索伪逆或伪逆。
public class Mixture {
public static void main(String[] args) {
// calculate an optimal mixture of A, B, C to make N
double A = Double.parseDouble(args[0]);
double B = Double.parseDouble(args[1]);
double C = Double.parseDouble(args[2]);
double N = Double.parseDouble(args[3]);
// these formulas were derived from calculations of the pseudo-inverse
// of the matrix {{A,B,C},{1,1,1}}
double S = A + B + C;
double T = A*A + B*B + C*C;
double D = (A-B)*(A-B) + (B-C)*(B-C) + (C-A)*(C-A);
double p1 = ( (3*A-S)*N + (-A*S+T)) / D;
double p2 = ( (3*B-S)*N + (-B*S+T)) / D;
double p3 = ( (3*C-S)*N + (-C*S+T)) / D;
// if pseudo-inverse calculation gives a negative weight, set weight to 0
// and calculate exact solution
if (p1<0) { p1 = 0; p2 = (N-C)/(B-C); p3 = (B-N)/(B-C); }
if (p2<0) { p2 = 0; p1 = (N-C)/(A-C); p3 = (A-N)/(A-C); }
if (p3<0) { p3 = 0; p1 = (N-B)/(A-B); p2 = (A-N)/(A-B); }
p1 = Math.round(p1*1000)/10.0;
p2 = Math.round(p2*1000)/10.0;
p3 = Math.round(p3*1000)/10.0;
System.out.println("Mixture weights: " + p1 + "%, " + p2 + "%, " + p3 + "%");
System.out.println("Check p1*A+p2*B+p3*C = " + ((p1*A+p2*B+p3*C)/100));
System.out.println("Check p1 + p2 + p3 = " + (p1+p2+p3) + "%");
}
}
关于algorithm - 确定比率以达到 3 个值的平均值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29685316/
我不太确定如何制作它,因此当在屏幕上绘制矩形时,它有可能是金色的。这是我的游戏随机生成随机矩形的当前代码: public void drawRectangle() { rects.clear(
我知道这个问题可能是简单的几何问题,但我正在为一个地理区域使用特定的 shapefile 并寻找特定的 gis 解决方案(希望是代码)。 本质上,我想找到覆盖每个独立地理边界的黑色区域。覆盖红色区域、
我有一个 wordpress 网站,我有 5 个低文本 HTML 比率的页面,这是用于类别页面、作者页面和主页。我删除了所有不必要的插件以减少代码,它去掉了一个(我之前有 6 个)。我知道删除代码行之
这个问题已经有答案了: Division of integers in Java [duplicate] (7 个回答) 已关闭 9 年前。 我的代码: public class Test { pub
我希望在缩小时保持视频嵌入 (iframe) 的尺寸不变。 此时会出现两条黑线,并且随着您将其缩小而变大。 示例:http://jsfiddle.net/k5nbmqau/ 最简单的方法是什么?我想在
我正在尝试创建一个“幻灯片”div,它以恒定的纵横比在屏幕中间居中。 结合这个trick用于居中和this one对于比率,我想出了这个: HTML Percentage
我正在寻找一个提供统计数据/图表的网站,该网站提供 Android 智能手机和平板电脑上最流行的分辨率/屏幕比例。需要它来设计 UI 并计划如何扩展。如果有人共享数据会很酷。 最佳答案 这是您要找的吗
在我的应用中,我允许用户以纵向模式录制视频。我在应用程序中使用它,这很好。但是,我正在实现一项功能以在 Instagram 上分享视频,其中视频必须是方形的。 将视频裁剪成正方形,比方说中间部分,是一
我需要从两台服务器创建“可靠性”报告 - 服务器 A 和服务器 B。 两者都跟踪其正常运行时间 - 或者更确切地说,在它们不可用的任何情况下。这些记录存储在 SQL Server 数据库表中 Even
您好,我想更改我的/etc/my.cnf 文件(mysql 的配置文件)。 以下值应该是多少才能使我的查询获得更好的性能。 query_cache_type = 1 query_cache_limit
目前我有一个布局,可以将一些缩略图拉入一个 grid - 每个缩略图都由一种样式定义,该样式使它们保持固定比例(大约 16:9),该比例由以下定义像素尺寸 (389px x 230px),但它们在高分
我有一个 wxPython 应用程序,带有一个框架和一个面板。该面板上有许多静态框,每个静态框都有按钮和文本框。 我刚刚开始阅读有关 sizer 的内容,但它们似乎可能超出了我的需要,或者它们可能正是
假设我正在构建一个基本的搜索引擎。我有一个字符串列表作为搜索结果,我想对搜索结果列表进行排序,最匹配的结果排在最前面。 我当前的代码如下所示(以命名参数为例) import difflib def o
我正在为一组物种生成生态位模型,我想使用 AUC 作为生态位质量的指标。开发 Maxent 的 Steven Phillips 在他的 Maxent 手册中提供了用于计算 R 中 AUC 的代码。但是
我在 LaunchScreen 中有一个 UIView。 我已将以下约束添加到此 UIView。 我希望我的红色 View 始终占屏幕的 35%。 我计算了 RedView 的高度: 我的 ViewC
我有一个包含列的数据框:Year 和 Min Delay。示例行如下: 2014 0 2014 2 2014 0 2014 4 2015 4 2015 4 2015
我需要 CSS/响应式代码方面的帮助。随着我的窗口大小减小,我需要所有元素以相同的比例减小。对此有疑问。箭头和公鸡不会随着视口(viewport)减小而减小。 公鸡脚的影子应该稍微被箭遮住。箭头主体(
我想创建 roofline 模型,但我遇到了每字节比率算法失败的问题。你能解释一下如何计算吗?该算法使用 5 点模板进行计算。 这是算法 for(int i=1; i
我有一个数据框,其中单元格用 float 填充,列名采用日期时间格式,格式为年+季度 - 例如“1995Q2”。我想划分其中两个列的值并将结果存储在一个新列中。我这样做了: df['ratio'] =
我有一个 8GB RAM 的生产服务器。我希望在服务器上托管 elastic、logstash 和 kibana。使用 docker compose。 每个容器的推荐 java 大小内存大小是多少。我
我是一名优秀的程序员,十分优秀!