当前位置: 首页 > news >正文

功能性的网站自己开网店怎么运营

功能性的网站,自己开网店怎么运营,顺德网页定制,wordpress图片旋转文章目录 数学原理代码实现测试 数学原理 平面方程可写为 A x B y C z D 0 AxByCzD0 AxByCzD0 假设 C C C不为0,则上式可以改写为 z a x b y d zaxbyd zaxbyd 则现有一组点 { p i } \{p_i\} {pi​},则根据 x i , y i x_i,y_i xi​,yi​以及平面…

文章目录

    • 数学原理
    • 代码实现
    • 测试

数学原理

平面方程可写为

A x + B y + C z + D = 0 Ax+By+Cz+D=0 Ax+By+Cz+D=0

假设 C C C不为0,则上式可以改写为

z = a x + b y + d z=ax+by+d z=ax+by+d

则现有一组点 { p i } \{p_i\} {pi},则根据 x i , y i x_i,y_i xi,yi以及平面方程,可以得到其对应的 z ^ i \hat z_i z^i

z ^ i = a x i + b y i + d \hat z_i=ax_i+by_i+d z^i=axi+byi+d

从而平面拟合就转换为了最小二乘问题

arg min ⁡ ∑ ∣ z i − z ^ i ∣ \argmin \sum \vert z_i-\hat z_i\vert argminziz^i

将其转换为矩阵形式,记

A = [ x 1 y 1 1 x 2 y 2 1 ⋮ ⋮ x n y n 1 ] , x = [ a b d ] , b = [ z 1 z 2 ⋮ z n ] A=\begin{bmatrix} x_1&y_1&1\\x_2&y_2&1\\\vdots&\vdots\\x_n&y_n&1 \end{bmatrix}, x=\begin{bmatrix}a\\b\\d\end{bmatrix}, b=\begin{bmatrix}z_1\\z_2\\\vdots\\z_n\end{bmatrix} A= x1x2xny1y2yn111 ,x= abd ,b= z1z2zn

则拟合方程变为

A x = b Ax=b Ax=b

相应地 x x x可写为

x = ( A T A ) − 1 A T b x=(A^TA)^{-1}A^Tb x=(ATA)1ATb

最小二乘法的原理可见:python实现最小二乘法

代码实现

其代码实现如下

import numpy as np
def planefit(points):xs, ys, zs = list(zip(*points))A = np.vstack([xs,ys,np.ones_like(xs)]).Tb = np.reshape(zs, [-1, 1])abd = np.linalg.inv(A.T @ A) @ A.T @ breturn abd.reshape(-1)

其中输入参数points为一组点。第一步将这些点进行坐标拆分,得到一一对应的xs, ys, zs。然后通过这些点,构造矩阵A和向量b,最后输出 ( A T A ) − 1 A T b (A^TA)^{-1}A^Tb (ATA)1ATb

测试

首先做一个初始化平面的函数,其功能是随机生成一组在平面中的点,并且为其添加一些噪声。

# 初始化平面
def initPlane(a, b, d, N, err=0.1):xs,ys = np.random.rand(2, N)zs = a*xs + b*ys + d + np.random.rand(N)*errreturn list(zip(xs, ys, zs))

然后用planefit函数对这些点进行拟合,通过对比二者之间的差异,来证实算法的有效性

import matplotlib.pyplot as pltpts = initPlane(2,3,4,100,1)
a,b,d = planefit(pts)xs, ys = np.indices([100,100])/100
zs = a*xs + b*ys + dax = plt.subplot(projection='3d')
ax.plot_surface(xs, ys, zs, cmap='jet')
ax.scatter(*np.array(pts).T, marker='*')
plt.show()

在这里插入图片描述

随着加入的噪声逐渐变大,拟合误差也越来越大

errs = [0.01, 0.1, 0.2, 0.5, 1, 3, 5]
fits = []
for err in errs:pts = initPlane(2,3,4,100,1)a,b,d = planefit(pts)fits.append([abs(a-2),abs(b-3),abs(d-4)])import pprint
pprint.pprint(fits)

[[0.09377971025135245, 0.023025216275622373, 0.4933931906466551],
[0.044310965250572654, 0.05681830483294226, 0.47952260969370997],
[0.051813469166934745, 0.017914573861143257, 0.47553046120193176],
[0.08578595894551588, 0.0464898508775029, 0.42791269232718054],
[0.011569662177250528, 0.15976404558136714, 0.4886516489062753],
[0.006829071411009302, 0.04832062421804073, 0.5193494695593301],
[0.1651263679674586, 0.0736367910618192, 0.44103226768552073]]


http://www.mmbaike.com/news/662.html

相关文章:

  • 新手如何做企业网站百度网页游戏排行榜
  • 客户如何找到做网站宣传的律师做电商必备的几个软件
  • 网站开发有哪些架构推广代理平台
  • 只做鱼网站品牌营销推广方案怎么做
  • php做网站软件百度seo点击排名优化
  • 网站怎么做竞价百度学术论文查重官网
  • 怎么看网站做没做备案如何查看百度指数
  • 最专业的企业营销型网站建设价格如何自己建个网站
  • ssh购物网站开发视频网站排名优化培训课程
  • 学代码的网站线上怎么做推广和宣传
  • 龙岗做网站的合肥seo关键词排名
  • 美食网站设计模板百度电话人工服务
  • 网站开发流程详细步骤外链发布平台有哪些
  • 哪个网站做服装定制好常州百度推广公司
  • 网站开发文案seo指的是搜索引擎营销
  • 石狮外贸网站建设公司报价广告优化师怎么学
  • 果洛电子商务网站建设平台运营
  • wordpress如何通过后台增加主菜单成都网站优化及推广
  • 怎么做论坛网站北京厦门网站优化
  • 建设银行网站为什么进不去百度关键词如何优化
  • 网站怎么识别PC 手机国外搜索引擎大全
  • 怎么在百度搜索到我的网站靠谱的广告联盟
  • 建设发展委员会官方网站ciliba磁力搜索引擎
  • wordpress站点路径小广告清理
  • 潍坊网站建设兼职seo技术分享博客
  • 门户网站建设的请示seo网站推广计划
  • 零售网站有哪些平台外呼系统电销
  • 网上做网站兼职网站统计分析平台
  • 摄影作品展示网站flash全站源码下载百度搜索
  • 网站域名备案查询可以免费投放广告的平台