Изобразить на экране график указанной функции (параметр D принимает следующие значения: -1; 0,5; 1; 1,5). Построить координатные оси и выполнить соответствующие надписи на них. y = D(sin(x)+x*x); x принадлежит [a;b] — Pascal(Паскаль)

uses graph;
const
x1=-2*pi;{начало и конец графика в реальных значениях}
x2=2*pi;
function F(d,x:real):real;
begin
F:=d*(sin(x)+x*x);
end;
var a,b,mx,my,x,dx,y1,y2,y3,y4:real;
    x0,y0,grD,px,py,grM,i,k:integer;
    s,s1:string;
begin
grD:=detect;
initgraph(grD,grM,'');
x0:=getmaxX div 2;{начало координат в центре экрана}
y0:=getmaxY div 2;
{коэффициенты по осям для перевода реальных координат в экранные}
mx:=600/(x2-x1);{длина в пикселах по оси Х/реальная длина}
my:=(y0-20)/F(1.5,x1);{длина оси по У/(макс}
SetBkColor(7); {цвет фона}
setlinestyle(0,0,1);{сплошная линия}
SetColor(1);{цвет линий осей}
line(0,y0,getmaxX,y0); {ось Х}
line(x0,getmaxy,x0,0); {ось У}
for i:=1 to 7 do   {максимальное количество засечек в одну сторону}
   begin
    line(x0-3,y0-round(10*i*my),x0+3,y0-round(10*i*my));{засечки на оси У}
    line(x0-3,y0+round(10*i*my),x0+3,y0+round(10*i*my));
    line(x0+round(i*mx),y0+3,x0+round(i*mx),Y0-3); {засечки на оси Х}
    line(x0-round(i*mx),y0+3,x0-round(i*mx),Y0-3);
    str(i*10,s);
    {подпись оси У}
    outtextXY(x0-20,y0-round(10*i*my),s);{соответственно засечкам}
    outtextXY(x0-25,y0+round(10*i*my),'-'+s);
    {подпись оси Х}
    str(i,s);
    outtextXY(x0+round(i*mx),y0+10,s);
    outtextXY(x0-round(i*mx),y0+10,'-'+s);
  end;
{центр}
outtextXY(x0+5,y0+10,'0');
{подписи концов осей}
outtextXY(getmaxX-10,y0-10,'X');
outtextXY(x0+10,10, 'Y');
dx:=0.001;
{график}
x:=x1;
while x<=x2 do
 begin
  px:=x0+round(x*mx); {изменение по оси Х}
  y1:=F(-1,x); {график в реальных координатах}
  py:=y0-round(y1*my);{в экранных}
  putpixel(px,py,4);
  y2:=F(0.5,x); {график в реальных координатах}
  py:=y0-round(y2*my);{в экранных}
  putpixel(px,py,2);
  y3:=F(1,x); {график в реальных координатах}
  py:=y0-round(y3*my);{в экранных}
  putpixel(px,py,9);
  y4:=F(1.5,x); {график в реальных координатах}
  py:=y0-round(y4*my);{в экранных}
  putpixel(px,py,14);
  x:=x+dx; {наращиваем х}
 end;
setcolor(10);
settextstyle(0,0,1);
outtextXY(55,30,'Grafik functii Y=D*(sin(x)+x^2)');
outtextXY(105,40,'interval [-2pi; 2pi]');
setcolor(4);
outtextXY(135,50,'A=-1');
setcolor(2);
outtextXY(135,60,'A=0.5');
setcolor(9);
outtextXY(135,70,'A=1');
setcolor(14);
outtextXY(135,80,'A=1.5');
readln
end.

Leave a Comment

+ 3 = 4