Image:Swastica curve3.png

From Wikipedia, the free encyclopedia

Wikimedia Commons logo This is a file from the Wikimedia Commons. The description on its description page there is shown below.
Commons is a freely licensed media file repository. You can help.
Description

The swastika curve

Source

self-made with MATLAB.

Date

05:54, 17 January 2008 (UTC)

Author

Oleg Alexandrov

Permission
(Reusing this image)

see below



Public domain I, the copyright holder of this work, hereby release it into the public domain. This applies worldwide.

In case this is not legally possible:
I grant anyone the right to use this work for any purpose, without any conditions, unless such conditions are required by law.


Afrikaans | Alemannisch | Aragonés | العربية | Asturianu | Български | Català | Česky | Cymraeg | Dansk | Deutsch | Eʋegbe | Ελληνικά | English | Español | Esperanto | Euskara | Estremeñu | فارسی | Français | Galego | 한국어 | हिन्दी | Hrvatski | Ido | Bahasa Indonesia | Íslenska | Italiano | עברית | Kurdî / كوردی | Latina | Lietuvių | Latviešu | Magyar | Македонски | Bahasa Melayu | Nederlands | ‪Norsk (bokmål)‬ | ‪Norsk (nynorsk)‬ | 日本語 | Polski | Português | Ripoarisch | Română | Русский | Shqip | Slovenčina | Slovenščina | Српски / Srpski | Svenska | ไทย | Tagalog | Türkçe | Українська | Tiếng Việt | Walon | ‪中文(简体)‬ | ‪中文(繁體)‬ | zh-yue-hant | +/-

[edit] MATLAB source code

% Swastika curve
 
function main()
 
   % linewidth and font size
   lw= 4; 
   fs = 25;
 
% colors
   red=[0.867 0.06 0.14];
   blue = [0, 129, 205]/256;
   green = [0, 200,  70]/256;
   black = [0, 0, 0];
   white = 0.99*[1, 1, 1];
 
   % Set up the plotting window
   figure(1); clf; set(gca, 'fontsize', fs, 'linewidth', lw/4);
   hold on; axis equal; grid on;
 
   N=500;  % number of points (don't make it big, code will be slow)
   Lx1 = -2; Lx2 = 2; Ly1 = -2; Ly2 = 2;
 
   [X, Y]=meshgrid(linspace(Lx1, Lx2, N), linspace(Ly1, Ly2, N));   % X and Y coordinates
 
   Ncurves = 10;
   A = linspace(0, 1, Ncurves);
 
   figure(2); clf; hold on; axis equal; axis off;
 
   x = X; y = Y;
   Z = y.^4-x.^4-x.*y;
 
%  graph the curves using 'contour' in figure (2)
   figure(2); [c, stuff] = contour(X, Y, Z, [0, 0]);
 
%  extract the curves from c and graph them in figure(1) using 'plot'
%  need to do this kind of convoluted work since plot2svg can't save
%  the result of 'contour' but can save the result of 'plot'   
 
   [m, n] = size(c);
   while n > 0
 
          l=c(2, 1);
          x=c(1,2:(l+1));  y=c(2,2:(l+1)); % get x and y of contours
          figure(1); plot(x, y, 'color', red, 'linewidth', lw);
 
          c = c(:, (l+2):n);
          [m, n] = size(c);
 
   end
 
   figure(1); axis equal; axis ([Lx1, Lx2, Ly1, Ly2]);
 
   set(gca, 'XTick', [-2, -1, 0, 1, 2]);  set(gca, 'YTick', [-2, -1, 0, 1, 2]);
   set(gca, 'GridLineStyle', '--');
 
   saveas(gcf, 'Swastica_curve3.eps', 'psc2')

File history

Click on a date/time to view the file as it appeared at that time.

Date/TimeDimensionsUserComment
current06:49, 17 January 2008587×579 (19 KB)Oleg Alexandrov (Tweak)
06:46, 17 January 2008587×579 (20 KB)Oleg Alexandrov (x and y labels)
06:46, 17 January 2008587×579 (20 KB)Oleg Alexandrov (x and y labels)
05:56, 17 January 2008549×558 (19 KB)Oleg Alexandrov (make curve thicker)
05:54, 17 January 2008549×558 (20 KB)Oleg Alexandrov ({{Information |Description=The en:swastica curve |Source=self-made with en:Matlab. |Date=~~~~~ |Author= Oleg Alexandrov }} {{PD-self}} ==MATLAB source code== <source lang="matlab"> % Swastika curve function main() )
The following pages on the English Wikipedia link to this file (pages on other projects are not listed):