李萨如曲线

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

数学上,利萨茹(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. Flink水印机制(watermark)

    Flink流处理时间方式 EventTime 时间发生的时间,例如:点击网站上的某个链接的时间 IngestionTime 某个Flink节点的source operator接收到数据的时间,例如:某 ...

  2. java反射(一)--认识反射机制

    一.认识java反射机制 在java语言中,之所以会有如此众多的开源技术支撑,很大的一部分来源于java最大特征--反射机制.能够灵活的去使用反射机制进行项目的开发与设计,才能够真正接触到java的精 ...

  3. Python - zipfile 乱码问题解决

    最近使用zipfile进行解包过程中遇到了很不舒服的问题,解包之后文件名是乱码的.下面进行简单总结: 首先,乱码肯定是因为解码方式不一样了,zipfile使用的是utf-8和cp437这两种编码方式, ...

  4. HttpClient 之 发送Https请求

    HttpClient包是一个优秀的Http请求的开源jar. 本文Http工具类的封装基于HttpClient,封装后的工具类支持Https请求. 但是由于项目的需要快速的实现,以下代码还可能会有点过 ...

  5. Java开发中的23种设计模式详解(1)创建型

    设计模式(Design Patterns) --可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...

  6. 【问题解决方案】git/github本地和远程仓库的重命名

    参考: CSDN博文:在Github上重命名仓库 背景: 偶然终于看到一条规范里写着: "通常(注意是通常,尤其是 Web 相关的项目) repo 的命名用小写英文,多个字母之间用连字符(比 ...

  7. Blueprint的实现

    Blueprint其实本身只是对view上的接口进行了注册,然后整体挂载在app上,Blueprint本身的目的就是组织多模块的平行共存,避免直接在app上注册view,其实更多的只是方便开发和代码的 ...

  8. GenXus学习笔记——Transaction的建立

    我们上次聊到 如何正确无误的的创建一个项目KB 那么这次我们就该聊一点实际的东西了(敲黑板( ̄▽ ̄))  上回书说道我们在创建完自己的KB后 该创建自己的数据库了 首先我们先创建创建一个表 但是创建之 ...

  9. Pandas之loc\iloc\ix

    ---------------------------------------------------------------------------------------------------- ...

  10. C# WinForm 提示框延迟自动关闭

    有时候我们需要弹出个提示框然后让它自己关闭,然而实际使用中的弹出框确实阻塞进程,网上貌似有一种另类的解决方式,大致思路是把弹出框放到另外的一个窗体上,直接贴代码 主窗体 using System; u ...