File:LimSup.png
頁面內容不支援其他語言。
外觀
預覽大小:800 × 409 像素。 其他解析度:320 × 164 像素 | 640 × 327 像素 | 996 × 509 像素。
原始檔案 (996 × 509 像素,檔案大小:46 KB,MIME 類型:image/png)
摘要
Made by myself with matlab.
File:LimSup.svg是本檔案的向量版本。 如果品質不低,就應該優先使用該檔案,而非PNG檔案。
File:LimSup.png → File:LimSup.svg
更多資訊請參閱Help:SVG/zh。
|
授權條款
Public domainPublic domainfalsefalse |
我,此作品的版權所有人,釋出此作品至公共領域。此授權條款在全世界均適用。 這可能在某些國家不合法,如果是的話: 我授予任何人有權利使用此作品於任何用途,除受法律約束外,不受任何限制。 |
Source code (MATLAB)
function main() % draw an illustration for limit superior and limit inferior
% prepare the screen and define some parameters
clf; hold on; axis equal; axis off;
fontsize=25; thick_line=3; thin_line=2;
black=[0, 0, 0]; red=[1, 0, 0]; blue=[0, 0, 1];
arrowsize=0.5; arrow_type=1; arrow_angle=30; % (angle in degrees)
circrad=0.07; % radius of ball showing up in places
B=9.4;
X=0:0.05:B;
f=inline('(X+2)./(X+0.9)', 'X');
Y=sin(5*X).*f(X);
for i=1:length(X)
ball(X(i), Y(i), circrad, blue);
end
K=1.5;
X=0:0.05:(B+K);
Z=f(X);
plot(X, Z, 'r--', 'linewidth', thin_line)
plot(X, -Z, 'r--', 'linewidth', thin_line)
L=f(B);
plot([B+0.4*K B+K], [L, L], 'linestyle', '-', 'linewidth', thick_line, 'color', red);
plot([B+0.4*K B+K], [-L, -L], 'linestyle', '-', 'linewidth', thick_line, 'color', red);
shift=2*K;
H=text(B+shift, L, 'lim sup'); set(H, 'fontsize', fontsize, 'HorizontalAlignment', 'c')
H=text(B+shift, -L, 'lim inf'); set(H, 'fontsize', fontsize, 'HorizontalAlignment', 'c')
shift=-3;
K1=1.2; K2=2.6;
arrow([-1 shift], [K1*B, shift], thin_line, arrowsize, arrow_angle, arrow_type, black)
arrow([-1, shift], [-1, K2*L], thin_line, arrowsize, arrow_angle, arrow_type, black)
axis ([-0.2*B, K1*B+1, -2*L+shift, K2*L]);
H=text(K1*B+0.6, shift, '\it{n}'); set(H, 'fontsize', fontsize, 'HorizontalAlignment', 'c')
H=text(-1, K2*L+0.5, '\it{x_n}'); set(H, 'fontsize', fontsize, 'HorizontalAlignment', 'c')
saveas(gcf, 'LimSup.eps', 'psc2') % export to eps
function ball(x, y, r, color)
Theta=0:0.1:2*pi;
X=r*cos(Theta)+x;
Y=r*sin(Theta)+y;
H=fill(X, Y, color);
set(H, 'EdgeColor', 'none');
function arrow(start, stop, thickness, arrow_size, sharpness, arrow_type, color)
% Function arguments:
% start, stop: start and end coordinates of arrow, vectors of size 2
% thickness: thickness of arrow stick
% arrow_size: the size of the two sides of the angle in this picture ->
% sharpness: angle between the arrow stick and arrow side, in degrees
% arrow_type: 1 for filled arrow, otherwise the arrow will be just two segments
% color: arrow color, a vector of length three with values in [0, 1]
% convert to complex numbers
i=sqrt(-1);
start=start(1)+i*start(2); stop=stop(1)+i*stop(2);
rotate_angle=exp(i*pi*sharpness/180);
% points making up the arrow tip (besides the "stop" point)
point1 = stop - (arrow_size*rotate_angle)*(stop-start)/abs(stop-start);
point2 = stop - (arrow_size/rotate_angle)*(stop-start)/abs(stop-start);
if arrow_type==1 % filled arrow
% plot the stick, but not till the end, looks bad
t=0.5*arrow_size*cos(pi*sharpness/180)/abs(stop-start); stop1=t*start+(1-t)*stop;
plot(real([start, stop1]), imag([start, stop1]), 'LineWidth', thickness, 'Color', color);
% fill the arrow
H=fill(real([stop, point1, point2]), imag([stop, point1, point2]), color);
set(H, 'EdgeColor', 'none')
else % two-segment arrow
plot(real([start, stop]), imag([start, stop]), 'LineWidth', thickness, 'Color', color);
plot(real([stop, point1]), imag([stop, point1]), 'LineWidth', thickness, 'Color', color);
plot(real([stop, point2]), imag([stop, point2]), 'LineWidth', thickness, 'Color', color);
end
在此檔案描寫的項目
描繪內容
檔案歷史
點選日期/時間以檢視該時間的檔案版本。
日期/時間 | 縮圖 | 尺寸 | 使用者 | 備註 | |
---|---|---|---|---|---|
目前 | 2007年2月24日 (六) 17:02 | 996 × 509(46 KB) | Oleg Alexandrov | Made by myself with matlab. |
檔案用途
沒有使用此檔案的頁面。
全域檔案使用狀況
以下其他 wiki 使用了這個檔案:
- ary.wikipedia.org 的使用狀況
- de.wikipedia.org 的使用狀況
- or.wikipedia.org 的使用狀況
- simple.wikipedia.org 的使用狀況
隱藏分類: