李萨如曲线

有没有对示波器上变化曲线产生过兴趣,它叫做李萨如曲线:

数学上,利萨茹(Lissajous)曲线(又称利萨茹图形、李萨如图形或鲍迪奇(Bowditch)曲线)是两个沿着互相垂直方向的正弦振动的合成的轨迹

(参见http://zh.wikipedia.org/wiki/%E5%88%A9%E8%90%A8%E8%8C%B9%E6%9B%B2%E7%BA%BF

代码

   1: //int n=4;

   2: int p=17;

   3: int q=15;

   4:  

   5: int a = displayWidth /2 ;

   6: int b = a;//displayHeight /2 ;

   7:  

   8: int radius = 2;

   9: float miu = 0;//PI / 2 / p;

  10: float miu_max = TWO_PI;

  11: float miu_delta = miu_max / 100;

  12:  

  13: public void setup() {

  14:   size(displayWidth, displayHeight);

  15:   background(0);

  16:   frameRate(2);

  17:   

  18:   a = displayWidth / 5 ;

  19:   b = a ;

  20: }

  21:  

  22: public void draw() {  

  23:  

  24:     miu += miu_delta;

  25:     if (miu >= miu_max)

  26:         miu = 0;

  27: //    if (miu >= miu_max)

  28: //    {

  29: //        miu_delta = -miu_delta;

  30: //        miu += miu_delta;

  31: //    }

  32: //    else if (miu < 0)

  33: //    {

  34: //        miu_delta = -miu_delta;

  35: //        miu += miu_delta;

  36: //    }

  37:     

  38:     fill(0,0,0,250);

  39:     rect(-1,-1, displayWidth+1, displayHeight+1);

  40:     

  41:     int last_x = -1;

  42:     int last_y = -1;

  43:     

  44:     for (float theta=0;theta<TWO_PI;theta+=TWO_PI/360)

  45:     {

  46:         int x = (int) (a * sin(p * theta)) + displayWidth /2;

  47:         int y = (int) (b * sin(q * theta + (miu))) + displayHeight /2;

  48:         

  49:         colorMode(HSB, 255);

  50:         stroke(90, 255, 255);

  51:         fill(90, 255, 255);

  52:         

  53:         if (last_x != -1 >> last_y != -1)

  54:         {

  55:             line(last_x, last_y, x, y);

  56:             line(last_x-1, last_y, x-1, y);

  57:         }

  58:         

  59:         last_x = x;

  60:         last_y = y;

  61:  

  62:         //ellipse(x, y, radius, radius);

  63:     }

  64:     

  65: }

截图

 

用processing画李萨如曲线的更多相关文章

  1. JavaScript动画实例:李萨如曲线

    在“JavaScript图形实例:阿基米德螺线”和“JavaScript图形实例:曲线方程”中,我们学习了利用曲线的方程绘制曲线的方法.如果想看看曲线是怎样绘制出来的,怎么办呢?编写简单的动画,就可以 ...

  2. 简单而粗暴的方法画任意阶数Bezier曲线

    简单而粗暴的方法画任意阶数Bezier曲线 虽然说是任意阶数,但是嘞,算法原理是可以到任意阶数,计算机大概到100多阶就会溢出了 Bezier曲线介绍] [本文代码] 背景 在windows的Open ...

  3. 用matlab画漂亮的sin曲线

    Technorati 标记: matlab,plot 相信大部分用过matlab的人都画过sin曲线,直接plot就可以了,不过呢,plot出来的曲线自然不那么好看,本着绳命在于折腾的原则,小弟学习了 ...

  4. 画caffe训练loss曲线

    Linux下操作 1. 将loss值存储到lossInf.txt中 fName1='loss.txt' cat loss.log | grep "solver.cpp:218] Iterat ...

  5. caffe-windows画loss与accuracy曲线

    参考博客: http://blog.csdn.net/sunshine_in_moon/article/details/53541573 进入tools/extra/文件夹中,修改plot_train ...

  6. JavaScript图形实例:阿基米德螺线

    1.阿基米德螺线 阿基米德螺线亦称“等速螺线”.当一点P沿动射线OP以等速率运动的同时,该射线又以等角速度绕点O旋转,点P的轨迹称为“阿基米德螺线”. 阿基米德螺线的笛卡尔坐标方程式为: r=10*( ...

  7. 数学图形(2.19) 利萨茹3D曲线

    在前面的章节数学图形(1.13) 利萨茹曲线中,写的是二维的利萨茹曲线,这一节,将其变为3D图形. #http://www.mathcurve.com/courbes3d/lissajous3d/li ...

  8. 精确率与召回率,RoC曲线与PR曲线

    在机器学习的算法评估中,尤其是分类算法评估中,我们经常听到精确率(precision)与召回率(recall),RoC曲线与PR曲线这些概念,那这些概念到底有什么用处呢? 首先,我们需要搞清楚几个拗口 ...

  9. koch曲线与koch雪花的MATLAB实现

    代码 % -- function koch(Ax, Ay, Bx, By) % 控制递归深度 Deepth = ; % 控制图画大小 Size = ; + (By-Ay)^) < Deepth ...

随机推荐

  1. idea下web工程的编译和输出设置

    公司的一个项目,别人用的eclipse,我这边用IDEA,路径上出了点问题,现在大概有点头绪了,记录下来. 打开project structure后,看到如下设置,最重要的是Modules和Artif ...

  2. 终于好了 ipython 里执行dos命令 显示结果却显示在kernel界面里 搞定了

    import os cmd = r'type c:\foo.txt' os.system(cmd) import os cmd = r'type c:\foo.txt' os.system(cmd) ...

  3. DLNA和UPNP

    继之前一个人研究ONVIF协议,SSDP协议,现在又要跳DLNA的坑,说到DLNA,必须离不开UPNP,这俩关系特好 DLNA官网:http://www.dlna.org/ UPNP官网:http:/ ...

  4. selenium:Xpath定位详解

    xpath定位在业界被戏称为元素定位的"屠龙宝刀",宝刀在手,武林我有.现在我们就来详解xpath定位方法. 一.xpath通过元素属性定位 xpath可以通过元素的属性来定位,如 ...

  5. 在虚拟机的Linux系统下安装wineqq

    |   版权声明:本文为博主原创文章,未经博主允许不得转载. 本文参考教程:http://www.ubuntukylin.com/ukylin/forum.php?mod=viewthread& ...

  6. JavaScript的日期对象

    1.Date对象用来处理日期和时间. 2.创建Date对象的语法: var myDate = new Date(); 3.Date对象的常用方法: 格式:Date.XX(); getDate() 从 ...

  7. cf:c题

    题目: 代码: #include<iostream> #include<algorithm> #include<vector> #include<string ...

  8. Python 的PIL,可以解决ImportError The _imagingft C module is not installed

    删除PIL相关文件 mv PIL /tmp   pip install Pillow 安装Pillow后, 可能还会发生KeyError的错误, 检查项目源码后发现是 Image 模块的save函数中 ...

  9. K8S操作

    一.K8Spods操作 kubectl delete all --all //删除 所有pods

  10. 基于mybatis拦截器分表实现

    1.拦截器简介 MyBatis提供了一种插件(plugin)的功能,但其实这是拦截器功能.基于这个拦截器我们可以选择在这些被拦截的方法执行前后加上某些逻辑或者在执行这些被拦截的方法时执行自己的逻辑. ...