środa, 10 kwietnia 2013

FLOSSowa wiosna

Cały czas trwają warsztaty programistyczne organizowane przez SzLUUG. Materiały z dotychczasowych prelekcji dostępne są na stronie. Mimo, że studenci (do których adresowano szkolenie) niezbyt dopisali frekwencją, to pewne że odbędzie się kolejna sesja warsztatowa. Ponownie poruszymy temat Git'a oraz prawdopodobnie rozpoczniemy cykl zajęć wprowadzających do Linux. Podczas szkolenia wyszło, że uczestnicy mają problem z elementarnym rozumieniem działania konsoli systemu. Polecenia echo, czy tworzenie pliku poprzez przekierowanie strumienia do nieistniejącego pliku przerosły niektórych. Chcemy to poprawić. Siła Windowsa nie polega na tym, że jest "łatwy". Windows nie jest łatwy, lecz maskując przez użytkownikiem ogrom możliwości jakie powinien dawać system operacyjny sprawia wrażenie prostego. To dziwne, ale mamy 2013 rok a standardowa konsola Windows dalej nie obsługuje wyrażeń regularnych.

Wracając, chcemy pokazać co powinien dawać użytkownikowi dobry system operacyjny i pokazać co może dać użytkownikowi Linux (bez wywyższania go spośród innych systemów). Chcemy pokazać podstawy poruszania się po systemie, wyjaśnić elementy struktury plikowo-dyskowej i wprowadzić do konsoli, a także podstawowych narzędzi (sed/awk/grep/echo/cat, ...). Może uda mi się wprowadzić po cichu kurs dla nauczycieli pokazujący nauczanie wspomagane komputerowo. Chętnie bym pokazał jak pracować z wykorzystaniem narzędzi z KDE-Edu (np. KStep) , narzędzi Tux4Kids, a także jak ciekawie uczyć nauk z pogranicza matematyki, robotyki i programowania (np. z użyciem Robocode).

Oby się udało ^^


Pomimo małej frekwencji na SzLUUGowych warsztatach z C udało się utworzyć fajny plug-in do programu TuxPaint. Autorem jest Łukasz Dmitrowski, który to został wciągnięty w projekt TuxPaint właśnie dzięki warsztatom. Plugin nazywa się XOR, działa w trybie pędzla (w przeciwieństwie do filtrów typu pełnoekranowego). Efektem jego działania jest utworzenie pod pędzlem mozaiki kolorystycznej. Tło pod pędzlem zostaje zamalowane. Kod znajduje się na GitHubie. Dobra robota, Łukasz :)




Opublikowano listy projektów zaakceptowanych w tegorocznym Google's Summer of Code. Życie jest piękne ^^

środa, 3 kwietnia 2013

Processing : gra w życie

Napisałem wizualizację gry w życie Conway'a w Processing.

Kod wygląda tak:
int ileKomorek=40;
int wysKomorki = 8;
int ileStartowych=300;
boolean[][] przed, po;

int ileSasiadow(int i, int j, int rozmiar)
{
  int ile=0;
  int[] xoff = {
    i-1, i, i+1
  };
  int[] yoff = {
    j-1, j, j+1
  };

  for (int ii=0; ii<3; ii++)
  {
    if (xoff[ii] < 0) xoff[ii]+=rozmiar;
    if (yoff[ii] < 0) yoff[ii]+=rozmiar;
    if (xoff[ii] >= rozmiar) xoff[ii]-=rozmiar;
    if (yoff[ii] >= rozmiar) yoff[ii]-=rozmiar;
  }

  for (int x=0; x<3; x++)
    for (int y=0; y<3; y++)
      if (x!=1 || y!=1)
        if (przed[xoff[x]][yoff[y]]) ile++;

  assert(ile>=0 && ile<=8);
  return ile;
}

void setup()
{
  size(ileKomorek*wysKomorki, ileKomorek*wysKomorki);
  background(255);
  przed = new boolean[ileKomorek][ileKomorek];
  po = new boolean[ileKomorek][ileKomorek];

  int i=0;
  while (i<ileStartowych)
  {
    if (!przed[int(random(0, ileKomorek))][int(random(0, ileKomorek))])
    {
      przed[int(random(0, ileKomorek))][int(random(0, ileKomorek))] = true;
      i++;
    }
  }
  fill(204, 102, 0);
  noStroke();
}

void draw()
{
  background(255);
  for (int i=0; i<ileKomorek; i++)
  {
    for (int j=0; j<ileKomorek; j++)
    {
      if (przed[i][j])
      {
        rect(i*wysKomorki, j*wysKomorki, wysKomorki, wysKomorki);
        po[i][j] = (ileSasiadow(i, j, ileKomorek) >=2 && ileSasiadow(i, j, ileKomorek) <= 3);
      }
      else if (ileSasiadow(i, j, ileKomorek) ==3) po[i][j] = true;
    }
  }

  for (int i=0; i<ileKomorek; i++)
    for (int j=0; j<ileKomorek; j++)
      przed[i][j]=po[i][j];
  delay(1000);
}
A teraz wyobraź sobie, że masz to samo napisać w C++ lub czymś jeszcze bardziej niskopoziomowym.
BTW: Przymierzam się do zrobienia implementacji w Haskell