Mihai Sprinceana
Un forum de programare cu de toate. Va astept sa va inscrieti si sa deveniti moderatori. Oricine este binevenit aici sa se inscrie si sa aiba acces la informatie free! Fiecare este liber sa adauge proiecte programe free etc. Ajutati acest forum sa devina o comunitate puternica unde fiecare invata de la fiecare! Tot ce trebuie sa faceti este sa va inregistrati si fiecare contributie se poate dovedi utila in timp! Forumul este free informatia free dk aveti timp liber ajutati si pe ceilalti si invatati si voi in acelasi timp! Haideti sa facem ceva pt.a ne ajuta intre noi! Cititi regulament postare forum inainte de a posta!
Lista Forumurilor Pe Tematici
Mihai Sprinceana | Inregistrare | Login

POZE MIHAI SPRINCEANA

Nu sunteti logat.
Nou pe simpatie:
iulia2006 Profile
Femeie
24 ani
Bucuresti
cauta Barbat
25 - 49 ani
Mihai Sprinceana / Programe RNRF / Calcul compacitate pentru o regiune =calcul factor forma Moderat de Laur69, fireratbat, profu.info, sade5000
Autor
Mesaj Pagini: 1
mihaispr
Administrator

Inregistrat: acum 18 ani
Postari: 2142
//Programul calculeaza compacitatea pt.o regiune aplicand formula P*P/A

//P-perimetrul regiunii, A-aria regiunii

//Problema este pt.cazul in care pixelii regiunii sunt tetra-conectati

#include<stdio.h>
#include<conio.h>
#include<process.h>
#include<stdlib.h>
#include<math.h>

FILE* f;

int a[9][9],i,j,arie;
float p;

void citire_img()
{
    if((f=fopen("test.txt","rb" ))==NULL)

  printf("\n\nNU POT DESCHIDE FISIERUL - (VERIFICATI CALEA CATRE FISIER)" );

else

  printf("\nMATRICEA A FOST CITITA DIN FISIER" );

    for(i=1;i<=8;i++)
    for(j=1;j<=8;j++)
     fscanf(f,"%d",&a[i][j]);
     fclose(f);
}

void afisare_img()

{
clrscr();

    for(i=1;i<=8;i++)
{
    for(j=1;j<=8;j++)
     printf("%d",a[i][j]);
     printf("\n" );
    }

}

void arie_reg()

{
   int count;
count=0;
   for(i=1;i<=8;i++)
{
    for(j=1;j<=8;j++)
     if(a[i][j]==1)
    count++;
}
     arie=count;
  printf("\nAria regiunii este: %d",arie);


}

void marcare()

{ int n,m,b;
b=1;
static int c=2;
for(i=1;i<=8;i++)                // scaneaza matricea
   for(j=1;j<=8;j++)

     if(a[i][j]==1)            // identifica primul pixel al regiunii

   {    for(n=-1;n<=1;n++)         // daca mai are vecini
      for(m=-1;m<=1;m++)
         if(a[i+n][j+m]==b)

          {   a[i][j]=c;       // este notat cu 2 ca si restul pixelilor
                   // ai regiunii
            b=c;
          }
             }
  ciclu:
   for(i=1;i<=8;i++)               // scaneaza matricea
     for(j=1;j<=8;j++)

     if(a[i][j]==1)                 // identifica alti pixeli ai regiuni
     {
       for(n=-1;n<=1;n++)
      for(m=-1;m<=1;m++)         // daca au vecini 2 atunci si acestia
         if(a[i+n][j+m]==c)       // fac parte din regiun
            {   a[i][j]=c;
            goto ciclu;  }
                       }

     afisare_img();
}




void perimetru()
{
  static int c=2;                 // declararea variabilelor locale
  int n,m,count;                // necesare functiei perimetru
  count=0;
  float suma=0;

///////////--MARCARE CONTUR--//////////////

ciclu:
   for(i=1;i<=8;i++)                 // scaneaza matricea
    for(j=1;j<=8;j++)                // identifica pixeli regiuni
     if(a[i][j]==c)
     {
    for(n=-1;n<=1;n++)           // verifica toti vecini pt fiecare pixel
      for(m=-1;m<=1;m++)         // ii ia in considerare numai pe cei
        if((n*m==0)&&(n!=m))     // care sunt tetra-conectati cu pixelul
      {

         if(a[i+n][j+m]!=0)       // ii contorizeaza
          count++;
         }
         if(count==4)        // daca nr lor sunt 4 pixelul face parte
           a[i][j]=1;        // centrul regiuni si este notat cu 1
           else
           a[i][j]=c;        // in caz contrar isi pastreaza valoarea

        count=0;   }

        for(i=1;i<=8;i++)
       for(j=1;j<=8;j++)        // seteaza toti pixeli notati cu 1
         if(a[i][j]==1)          // la valoarea fondului
           a[i][j]=0;


///////////--CALCULUL PERIMETRULUI--////////////////

    for(i=1;i<=8;i++)
     for(j=1;j<=8;j++)

     if(a[i][j]==c)
       {    for(n=-1;n<=1;n++)
         for(m=-1;m<=1;m++)
      if((n*m==0)&&(n!=m))

     {  if(a[i+n][j+m]==0)
          count++;                // Calculeaza cu cat contribuie la
               }          // perimetru un anumit pixel


     if(count<=2)                 // Daca are doar vecini tetraconectati
           suma=suma+1;      //  (oriz/vert), atunci p=1.
           else
     if(count==3)                  //  Daca are ambele tipuri de vecini
           suma=suma+1.207;    //  atunci p=1.207
           else
      if(count==4)                  // Daca are doar vecini octoconectati
           suma=suma+1.414;     // (diagonali), atunci p=1.414

            count=0;
                }

               p=suma;

         afisare_img();
        printf("\n" );
      printf("\nAria regiunii este: %d\n",arie);
     printf("Perimetrul regiuni= %f",p);
}



void calcul_circularitate()
{

   float compacitate,pi;
pi=3.14;

   compacitate= pow(p,2)/arie; //formula matematica de calcul a compacitatii
   printf("\nCircularitatea este=%f",circularitate);


}

void main(void)

{
  clrscr();

    citire_img();
     afisare_img();
     arie_reg();
     marcare();
     perimetru();
     calcul_compacitate();

getch();
}


Obs. Fisierul test.txt contine o regiune marcata de pixeli=1 ce reprezinta un patrat. Modificati la regiune pt.a obtine alte forme(cerc,triunghi etc marcand pixelii cu 1 care sa reprezinte o forma; in cazul nostru avem un patrat). Copiati fisierul test.txt in aceeasi cale unde ati salvat si codul sursa compacitate.cpp ce are codul sursa listat mai sus.


Iata si continutul fisierului test.txt:


0 0 0 0 0 0 0 0
0 0 0 1 1 1 1 0
0 0 0 1 1 1 1 0
0 0 0 1 1 1 1 0
0 0 0 1 1 1 1 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0


pus acum 17 ani
   
Pagini: 1  

Mergi la