Kuvan normalisointi

harrastaja591

Tässä on 3 melkein samanlaista funktiota, jotka ottavat viitteen virtaolioon, vectorit joka rgb-kanavalle ja tekevät raakakuva-tiedoston, jonka voi avata kuvankäsittelyohjelmalla jos tietää leveyden ja korkeuden.

Vaikka 2D-tilasto 1D-vectorina syötettynä tai sumuisena päivänä otettu digikuva näkyy kirkkaammissa ja selkeämmissä väreissä kun sen käyttää normalisointifunktiossa. Väriliukumat ovat jatkuvampia kun laskenta tehdään liukuluvuilla ennen 256 asteisiksi (unsigned) chareiksi muuttamista.

Muuten, outo ja hämäävä juttu, että raakakuvaa luettaessa lausekkeella "virtaolio > > noskipws > > muuttuja", muuttujan on oltava "unsigned char" tai ohjelma toimii väärin.

Olisi hyvä saada 3D-ohjelmien (Irrlicht ...)ruudunkaappaukset ja raytracing-kuvat liukuluvuista normalisoituina.

Korvatkaa pienempi_kuin ja suurempi_kuin editorin korvaustoiminnolla.

#includepienempi_kuiniostreamsuurempi_kuin
#includepienempi_kuinvectorsuurempi_kuin
#include pienempi_kuinstringsuurempi_kuin
#include pienempi_kuinfstreamsuurempi_kuin
#includepienempi_kuincstdlibsuurempi_kuin
#includepienempi_kuincmathsuurempi_kuin
using namespace std;


int rgbnorm(vectorpienempi_kuinfloatsuurempi_kuin vfr, vectorpienempi_kuinfloatsuurempi_kuin vfg, vectorpienempi_kuinfloatsuurempi_kuin vfb, fstream &tuotosn)
{
int t;
float np=0.001;
float fr, fg, fb;
int pxlkm=vfr.size();
float yennr, yenng, yennb, aennr, aenng, aennb;
char vR, vG, vB;
yennr=-1234559;yenng=-1234560;yennb=-1234572;
aennr=9912345678.1;aenng=9912345678.2;aennb=9912345678.3;
for(t=0 ; tpienempi_kuinpxlkm ; t )
{
fr=0; fg=0; fb=0;
fr=vfr.at(t);
fg=vfg.at(t);
fb=vfb.at(t);
if(frsuurempi_kuinyennr) yennr=fr; if(frpienempi_kuinaennr) aennr=fr;
if(fgsuurempi_kuinyenng) yenng=fg; if(fgpienempi_kuinaenng) aenng=fg;
if(fbsuurempi_kuinyennb) yennb=fb; if(fbpienempi_kuinaennb) aennb=fb;
}

for(t=0 ; tpienempi_kuinpxlkm ; t )
{
vR=(vfr.at(t)-aennr)*(254.0/( (yennr-aennr) np) );
vG=(vfg.at(t)-aenng)*(254.0/( (yenng-aenng) np) );
vB=(vfb.at(t)-aennb)*(254.0/( (yennb-aennb) np) );
tuotosn pienempi_kuinpienempi_kuin vR pienempi_kuinpienempi_kuin vG pienempi_kuinpienempi_kuin vB;
}
cout pienempi_kuinpienempi_kuin" ylin-r: "pienempi_kuinpienempi_kuin yennr pienempi_kuinpienempi_kuin " alin-r: "pienempi_kuinpienempi_kuin aennr pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yennr-aennr pienempi_kuinpienempi_kuinendl;
cout pienempi_kuinpienempi_kuin" ylin-g: "pienempi_kuinpienempi_kuin yenng pienempi_kuinpienempi_kuin " alin-g: "pienempi_kuinpienempi_kuin aenng pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yenng-aenng pienempi_kuinpienempi_kuinendl;
cout pienempi_kuinpienempi_kuin" ylin-b: "pienempi_kuinpienempi_kuin yennb pienempi_kuinpienempi_kuin " alin-b: "pienempi_kuinpienempi_kuin aennb pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yennb-aennb pienempi_kuinpienempi_kuinendl;


return 0;
}

4

253

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • harrastaja591

      int rgbnormkh(vectorpienempi_kuinfloatsuurempi_kuin vfr, vectorpienempi_kuinfloatsuurempi_kuin vfg, vectorpienempi_kuinfloatsuurempi_kuin vfb, fstream &tuotosn)
      {
      int t;
      float np=0.001;
      float fr, fg, fb;
      int pxlkm=vfr.size();
      float yennr, yenng, yennb, aennr, aenng, aennb;
      char vR, vG, vB;
      yennr=-1234559;yenng=-1234560;yennb=-1234572;
      aennr=9912345678.8;aenng=9912345678.6;aennb=9912345678.4;
      for(t=0 ; tpienempi_kuinpxlkm ; t )
      {
      fr=0; fg=0; fb=0;
      fr=vfr.at(t);
      fg=vfg.at(t);
      fb=vfb.at(t);
      if(frsuurempi_kuinyennr) yennr=fr; if(frpienempi_kuinaennr) aennr=fr;
      if(fgsuurempi_kuinyenng) yenng=fg; if(fgpienempi_kuinaenng) aenng=fg;
      if(fbsuurempi_kuinyennb) yennb=fb; if(fbpienempi_kuinaennb) aennb=fb;
      }

      for(t=0 ; tpienempi_kuinpxlkm ; t )
      {
      vR=(vfr.at(t)-aennr)*(253.5/( (yennr-aennr) np) ) 1.0/((rand()0) 1);
      vG=(vfg.at(t)-aenng)*(253.5/( (yenng-aenng) np) ) 1.0/((rand()0) 1);
      vB=(vfb.at(t)-aennb)*(253.5/( (yennb-aennb) np) ) 1.0/((rand()0) 1);
      tuotosn pienempi_kuinpienempi_kuin vR pienempi_kuinpienempi_kuin vG pienempi_kuinpienempi_kuin vB;
      }
      cout pienempi_kuinpienempi_kuin" ylin-r: "pienempi_kuinpienempi_kuin yennr pienempi_kuinpienempi_kuin " alin-r: "pienempi_kuinpienempi_kuin aennr pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yennr-aennr pienempi_kuinpienempi_kuinendl;
      cout pienempi_kuinpienempi_kuin" ylin-g: "pienempi_kuinpienempi_kuin yenng pienempi_kuinpienempi_kuin " alin-g: "pienempi_kuinpienempi_kuin aenng pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yenng-aenng pienempi_kuinpienempi_kuinendl;
      cout pienempi_kuinpienempi_kuin" ylin-b: "pienempi_kuinpienempi_kuin yennb pienempi_kuinpienempi_kuin " alin-b: "pienempi_kuinpienempi_kuin aennb pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yennb-aennb pienempi_kuinpienempi_kuinendl;


      return 0;
      }


      int rgbnormp(vectorpienempi_kuinfloatsuurempi_kuin vfr, vectorpienempi_kuinfloatsuurempi_kuin vfg, vectorpienempi_kuinfloatsuurempi_kuin vfb, fstream &tuotosn, float exp)
      {
      int t;
      float np=0.001;
      float fr, fg, fb;
      int pxlkm=vfr.size();
      float yennr, yenng, yennb, aennr, aenng, aennb;
      char vR, vG, vB;
      yennr=-91234559.0;yenng=-912345609.0;yennb=-912345729.0;
      aennr=9999912345678.0;aenng=99999123456789.0;aennb=99999123456789.0;

      for(t=0 ; tpienempi_kuinpxlkm ; t )
      {
      fr=0; fg=0; fb=0;
      vfr.at(t)=pow(vfr.at(t), exp);
      vfg.at(t)=pow(vfg.at(t), exp);
      vfb.at(t)=pow(vfb.at(t), exp);
      }



      for(t=0 ; tpienempi_kuinpxlkm ; t )
      {
      fr=0; fg=0; fb=0;
      fr=vfr.at(t);
      fg=vfg.at(t);
      fb=vfb.at(t);
      if(frsuurempi_kuinyennr) yennr=fr; if(frpienempi_kuinaennr) aennr=fr;
      if(fgsuurempi_kuinyenng) yenng=fg; if(fgpienempi_kuinaenng) aenng=fg;
      if(fbsuurempi_kuinyennb) yennb=fb; if(fbpienempi_kuinaennb) aennb=fb;
      }

      for(t=0 ; tpienempi_kuinpxlkm ; t )
      {
      vR=(vfr.at(t)-aennr)*(254.0/( (yennr-aennr) np) );
      vG=(vfg.at(t)-aenng)*(254.0/( (yenng-aenng) np) );
      vB=(vfb.at(t)-aennb)*(254.0/( (yennb-aennb) np) );
      tuotosn pienempi_kuinpienempi_kuin vR pienempi_kuinpienempi_kuin vG pienempi_kuinpienempi_kuin vB;
      }
      cout pienempi_kuinpienempi_kuin" ylin-r: "pienempi_kuinpienempi_kuin yennr pienempi_kuinpienempi_kuin " alin-r: "pienempi_kuinpienempi_kuin aennr pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yennr-aennr pienempi_kuinpienempi_kuinendl;
      cout pienempi_kuinpienempi_kuin" ylin-g: "pienempi_kuinpienempi_kuin yenng pienempi_kuinpienempi_kuin " alin-g: "pienempi_kuinpienempi_kuin aenng pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yenng-aenng pienempi_kuinpienempi_kuinendl;
      cout pienempi_kuinpienempi_kuin" ylin-b: "pienempi_kuinpienempi_kuin yennb pienempi_kuinpienempi_kuin " alin-b: "pienempi_kuinpienempi_kuin aennb pienempi_kuinpienempi_kuin " " pienempi_kuinpienempi_kuin yennb-aennb pienempi_kuinpienempi_kuinendl;

      return 0;
      }

      • harrastaja591

        Bonustehtävänä voi tehdä funktion jonka käytön seurauksena on muuttaa nollaksi eli mustaksi vectorin alimmat 10% ja 255:dksi eli maksimikirkkaaksi väriksi ylimmät 10%. Monenlainen kuva selkenisi siinä huomattavasti.

        Mutta miten tehdä se ilman kahdesti lajittelua?

        Väriarvot pitäisi laittaa structiin kuvan kohtaan liittyvän int järjestysnumeron kanssa.

        Sitten lajitellaan liukulukujen perusteella, leikataan ylimmät ja alimmat, normalisoidaan ja lajitellaan taas alkuperäiseen järjestykseen int ien perusteella. Kai on joku nopeampi keino? Toisaalta, ei se odotus niin kauan kestäisi...


      • qwerty.

        Hankala lukea, laitetaan natsat takaisin

        int rgbnormkh(vector vfr, vector vfg, vector vfb, fstream &tuotosn)
        {
        int t;
        float np=0.001;
        float fr, fg, fb;
        int pxlkm=vfr.size();
        float yennr, yenng, yennb, aennr, aenng, aennb;
        char vR, vG, vB;
        yennr=-1234559;yenng=-1234560;yennb=-1234572;
        aennr=9912345678.8;aenng=9912345678.6;aennb=9912345678.4;
        for(t=0 ; tyennr) yennr=fr; if(fryenng) yenng=fg; if(fgyennb) yennb=fb; if(fb


      • Ei oo noin vaikeeta
        qwerty. kirjoitti:

        Hankala lukea, laitetaan natsat takaisin

        int rgbnormkh(vector vfr, vector vfg, vector vfb, fstream &tuotosn)
        {
        int t;
        float np=0.001;
        float fr, fg, fb;
        int pxlkm=vfr.size();
        float yennr, yenng, yennb, aennr, aenng, aennb;
        char vR, vG, vB;
        yennr=-1234559;yenng=-1234560;yennb=-1234572;
        aennr=9912345678.8;aenng=9912345678.6;aennb=9912345678.4;
        for(t=0 ; tyennr) yennr=fr; if(fryenng) yenng=fg; if(fgyennb) yennb=fb; if(fb

        Koodatessa kannattaa muistaa, että mikä tahansa ohjelmalohko kuten esimerkiksi funktio, joka ei ei mahdu kaikilta riveiltään näyttöön siten, että ei tarvitse vierittää ruutuja ylös ja alas, että näkee lohkon joka kohdasta, on liian pitkä. Liian pitkä ohjelmalohko tai funktio pitää jakaa funktioitten kutsuihin. Jätin tuosta malllifunktiosta natsat pois, kun kerran haluatte kometoriville koodata, vaikka suoraan ikkunaan on paljon kätevämpi ohjelmoida ja tulostaa ja siitä lukea, että kaikki näkee sen:

        void __fastcall TTrackerForm::SmiToSbvClick(TObject *Sender)
        {
        AnsiString FName=SongSami->Text;
        FName=FName.SubString(1,FName.Length()-3) "SBV";
        int hFile=FileCreate(FName);
        for(int R=1; R< Lyrics->RowCount; R )
        {
        AnsiString sStartTime=Lyrics->Cells[0][R];
        AnsiString sEndTime=Lyrics->Cells[0][R == Lyrics->RowCount-1 ? R : R 1];
        FileWrite(hFile,sStartTime.c_str(),sStartTime.Length());
        FileWrite(hFile,",",1);
        FileWrite(hFile,sEndTime.c_str(),sEndTime.Length());
        FileWrite(hFile,"\n",1);
        AnsiString sCaption=Lyrics->Cells[1][R];
        FileWrite(hFile,sCaption.c_str(),sCaption.Length());
        FileWrite(hFile,"\n\n",2);
        }
        FileClose(hFile);
        }

        Tuosta voi kuka tahansa ihan helposti päätellä käänteisesti, kuinka tiedostosta luetaan, mutta pääsääntö on, että kannattaa ensin yrittää kirjoittaa tiedostoon ja vasta sitten yrittää sieltä tiedostosta lukea, jotta tietää, miten homma toimii!


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Aivosyöpää sairastava Olga Temonen TV:ssä - Viimeinen Perjantai-keskusteluohjelma ulos

      Näyttelijä-yrittäjä Olga Temonen sairastaa neljännen asteen glioomaa eli aivosyöpää, jota ei ole mahdollista leikata. Hä
      Maailman menoa
      91
      2920
    2. Pelotelkaa niin paljon kuin sielu sietää.

      Mutta ei mene perille asti. Miksi Venäjä hyökkäisi Suomeen? No, tottahan se tietenkin on jos Suomi joka ei ole edes soda
      Maailman menoa
      299
      1686
    3. Mikä saa ihmisen tekemään tällaista?

      Onko se huomatuksi tulemisen tarve tosiaan niin iso tarve, että nuoruuttaan ja tietämättömyyttään pilataan loppuelämä?
      Sinkut
      246
      1567
    4. Minkä merkkisellä

      Autolla kaivattusi ajaa? Mies jota kaipaan ajaa Mersulla.
      Ikävä
      87
      1391
    5. IL - VARUSMIEHIÄ lähetetään jatkossa NATO-tehtäviin ulkomaille!

      Suomen puolustuksen uudet linjaukset: Varusmiehiä suunnitellaan Nato-tehtäviin Puolustusministeri Antti Häkkänen esittel
      Maailman menoa
      402
      1384
    6. Nyt kun Pride on ohi 3.0

      Edelliset kaksi ketjua tuli täyteen. Pidetään siis edelleen tämä asia esillä. Raamattu opettaa johdonmukaisesti, että
      Luterilaisuus
      402
      1308
    7. Kiitos nainen

      Kuitenkin. Olet sitten ajanmerkkinä. Tuskin enää sinua näen ja huomasitko, että olit siinä viimeisen kerran samassa paik
      Tunteet
      2
      1089
    8. Esko Eerikäinen tatuoi kasvoihinsa rakkaan nimen - Kärkäs kommentti "Ritvasta" lävähti somessa

      Ohhoh! Esko Eerikäinen on ottanut uuden tatuoinnin. Kyseessä ei ole mikä tahansa kuva minne tahansa, vaan Eerikäisen tat
      Suomalaiset julkkikset
      38
      1047
    9. Hyväksytkö sinä sen että päättäjämme ei rakenna rauhaa Venäjän kanssa?

      Vielä kun sota ehkäpä voitaisiin välttää rauhanponnisteluilla niin millä verukkeella voidaan sanoa että on hyvä asia kun
      Maailman menoa
      329
      874
    10. Miksi Purra-graffiti ei nyt olekkaan naisvihaa?

      "Pohtikaapa reaktiota, jos vastaava graffiti olisi tehty Sanna Marinista", kysyy Tere Sammallahti. Helsingin Suvilahden
      Maailman menoa
      257
      855
    Aihe