воскресенье, июля 18, 2010

"Мегафон" предоставит второй номер для одной SIM- карты


Московское отделение « Мегафона» начало предоставлять своим абонентам новую услугу под на одной SIM-карте, причём второй – городской телефонный номер в коде 499 – тоже сможет принимать входящие вызовы и SMS-сообщения. Дополнительный номер не будет иметь отдельного лицевого счёта – пополнение баланса будет осуществляться точно так же, как к этому привыкли абоненты. Стоимость звонка на московский номер будет работать в роуминге по всей территории России. Стоимость новой услуги составляет 250 рублей в месяц, а подключить её можно абсолютно бесплатно в любом из офисов продаж и обслуживания сети «Мегафон
 «Мегафон» предоставит второй номер для одной SIM-карты | Новости Hardware - 3DNews - Daily Digital Digest 

Язык роботов ROILA


Все кто когда-либо задумывался о робототехнике, представляет себя актуальность проблемы взаимодействия оператора с роботом. В текущий момент наиболее адекватным выбором является речь, но текущий уровень данной технологии не позволяет использовать для этой цели естественные языки. Тут-то и приходит на помощь ROILA (RObot Interaction LAnguage). Он создан на основе нескольких африканских языков, голландского и испанского. Прост для распознавания речи текущими средствами р включает в себя около 850 слов.
По материалам статьи: Почему людям придется учить язык роботов?

Необычные авто ( почти гаджеты)

Сегодня пока утром серфил по нету наткнулся на очень интересный сайт "Автомобили 2.0" посвященный концептам автомобилей. На этом сайте публикуются новости связанные с необычными автомобилями. Примеры авто попадающих на сайт в моем поста. 

Эпидемия счастья


Исследователи уже выяснили, что полнота, одиночество, курение и даже развод «заразны». Исследование "Эмоции как инфекционные болезни в больших социальных сетях" только подтвердило эти мысли. Подробнее смотреть тут:
Счастье и несчастье не только передаются, но и могут становиться эпидемиями

Хорошая новость для пользователей Google


На  днях появилось сообщение что 
Google тестирует механизм мультиавторизации
Посмотрим что выйдет, должно быть полезно и вкусно.

суббота, июля 17, 2010

Небывалая мобильность интерфейсов комьютера

Студент Тони Старк изобрел лампу - в которой совмещены и проектор вывода интерфейса на любую поверхность и камера для распознания действий пользователя. С этим изобретением он выиграл Audi Innovation Challenge
http://www.youtube.com/watch?v=b45BpeVDx9w

среда, июля 14, 2010

Первичный анализ по проекту netBot


1. Структура системы должна быть полностью модульной. Т.е. каждый ключевой элемент системы (будь то драйвер устройства, модуль внутреннего представления иди часть конвеера обработки данных)
2. Робот должен иметь представление о своем составе и состоянии каждого из компонентов (внутренняя модель робота)
3. Система управления базируюется на событиях и обработка событий должна быть декларативной а обработчики событий расширяемыми.

Проект netBot - C# проект по управлению роботами

Объявляю о создании проекта посвященному робототехнике.
Проект - система позволяющая управлять роботом и писать алгоритмы для автономного управления роботом на языке C#.
Система должна включать в себя

  1. Подсистему общения с сенсорами
  2. Подсистему движения\позиционирования
  3. Подсистему компьютерного зрения
Так-же система должна включать в себя спецификацю на устройства\сенсоры и спецификацию на драйвера к этим устройствам.
Дальнейший анализ требований буду проводить здесь-же - в моем блоге

вторник, июля 13, 2010

Система ведения логов

Приглядевшись к своим исходникам я понял что нечто подобное всегда приходится делать некую систему для ведения логов необходимых для отладки. И вот я решил обобщить все что я использовал в своих проектах до этого и выделить в отдельную библиотеку классов.


Требования

  1. Конфигурация должна быть легкой
  2. Система должна быть легко расширяема
  3. Система должна предоставлять множественные способы вывода данных
  4. Система должна обладать возможностью перехвата необработанных исключений
  5. Система должна иметь статический и нестатический интерфейсы.

Архитектура



Принятые решения по архитектуре можно увидеть на приведенной ниже диаграмме: Структура классов


Интересные места


Перехват исключений
/// <summary>
/// Установить перехватчик исключений на заданный домен приложений
/// </summary>
/// <param name="dom"> </param>Домен для установки перехватчика
public void SetupIntercept( AppDomain dom )
{  
 dom.UnhandledException += ( s, e ) => {     
  Logger.Instance.Log(new LogMsg() {      
   Exception = (Exception)e.ExceptionObject, 
   Lvl = 100,
   Msg = "------ Unhandled Exception ------\n"
  }); 
 };

 dom.FirstChanceException += ( s, e ) => {
  Logger.Instance.Log(new LogMsg()
  {
   Exception = e.Exception,
   Lvl = 80,
   Msg = "------ First Chance Exception ------\n"
  }); 
 };
}

Дальнейшее развитие



  • Канал для записи данных в Базу данных
  • Канал позволяющий передавать сообщения на внешний сервер
  • Приложение - сервер логов


Если у вас есть вопросы - пишите. Исходники тут


C# 4.0 Новое в языке


Новые возможности .NET 4.0: C# 4.0

После выхода Visual Studio 2010 beta 1 - первым делом нужно разобраться, что же дает нового нам C# 4.0 (так как это мой основной язык программирования - для меня это является важным). Первым делом должен вам порекомендовать примеры C# 4.0, которые можно скачать отсюда (там же есть документ New Features in C# 4.0, которая послужила основой для этого топика). Документацию по .Net Framework 4.0 beta 1 можно посмотреть в MSDN. Дальше будут следовать мой небольшой опыт знакомства с новой версией .NET.

1. Dynamic Language Runtime

Изначально стоит взглянуть на следующую схему, иллюстрирующую архитектуру DLR: 
Именно! Теперь в .net можно еще и скриптовые языки использовать, такие как IronRuby и IronPython. Не думаю, что я буду этим пользоваться, но любителям экзотики предоставляю ссылки:
  • IronPython. - open-source проект на CodePlex.
  • IronRuby. - open-source проект на RubyForge.
Более того, предоставляется исходники DLR, при помощи которых вы, наверняка, сможете создать свой динамический язык для .NET, если вам это необходимо
Итак DLR включает в себя Expression Trees, которые просто являются представлением вызовов методов или бинарных операций в виде дерева, их функциональность можно посмотреть на следующем примере:
Expression<int, bool>> exprTree = num => num < 5;
// Decompose the expression tree.
ParameterExpression param = (ParameterExpression)exprTree.Parameters[0];
BinaryExpression operation = (BinaryExpression)exprTree.Body;
ParameterExpression left = (ParameterExpression)operation.Left;
ConstantExpression right = (ConstantExpression)operation.Right;
Console.WriteLine("Decomposed expression: {0} => {1} {2} {3}",
               param.Name, left.Name, operation.NodeType, right.Value);
В этом примере мы сначала описываем лямбда выражение x=>x<5, а затем при помощи объектов от Expression Trees разбираем данное выражение.
Call Site caching в DLR - это, насколько я понимаю, и есть динамическое представление вызовов методов динамических объектов или операций над динамическим объектами. DLR кеширует характеристики объектов (о типах объектах), а так же об операции, и если данная операция уже была выполнена ранее, тогда всю необходимую информацию DLR получит уже из кеша (вот как то так).
И последнее в DLR это набор классов, интерфейсов: IDynamicMetaObjectProvider, DynamicMetaObject, DynamicObject и ExpandoObject. Давайте опять посмотрим на примере, как нам это может пригодиться, и зачем нам вообще нужен этот DLR:
class Test1
{
}
 
static void Main(string[] args)
{
  dynamic t = new Test1();
  string str = t.Hello(); // Error 1 
 
  dynamic d = 7.0;
  int i = d; // Error 2
}
На удивление данный код скомпилируется и запустится. Все дело в волшебном слове dynamic, оно нам позволяет вызывать любые по имени свойства или методы, а так же приводить объект к любому типу. Во время Runtime (выполнения кода) вылетят ошибки, Error 1: о том, что метод не найден, Error 2: о том, что double невозможно привести к int. Попробуем их исправить:  для исправления первой ошибки наш класс Test1 отнаследуем от типа System.Dynamic.DynamicObject и перегрузим один из методов, для исправления второй просто явно укажем преобразование типов:
class Test1 : DynamicObject
{
  public override bool TryInvokeMember(InvokeMemberBinder binder, object[] args, out object result)
  {
    if (binder.Name == "Hello")
    {
      result = "Test1 is Dynamic Object!";
      return true;
    }
    return base.TryInvokeMember(binder, args, out result);
  }
}
 
static void Main(string[] args)
{
  dynamic t = new Test1();
  string str = t.Hello(); 
 
  dynamic d = 7.0;
  int i = (int) d;
}
Теперь наш код будет работать. Переменная str получить значение "Test1 is dynamic object!", а значение 7.
Конечно, необязательно наследоваться от класса DynamicObject, можно отнаследоваться и от интерфейсаIDynamicMetaObjectProvider, но тогда нужно будет самому реализовывать метод  DynamicMetaObject GetMetaObject(Expression parameter), и более того реализовывать свой тип, унаследованный от DynamicMetaObject, ну в любом случае варианты есть - так что можно взять на вооружение.

2. Именованные и необязательные параметры в методах

Это достаточно простая функциональность и уже много где оговорена, она хорошо описана вот например тут (на русском языке одним из автором хабрахабра). Если парой слов, то это возможность устанавливать дефолтные значения у параметров методов, а так же возможность установки значения параметра по имени при вызове метода. В общем пример будет лучшим объяснением:
class Test1 
{
  public void Method(int a = 0, string b = "Hello", bool c = true)
  {
    Console.WriteLine("{0}, {1}, {2}", a, b, c);
  }
}
 
static void Main(string[] args)
{
  Test1 o = new Test1();
  // Вызовем по как обычно
  o.Method(1, "Hello", true);
  // А можно поменять порядок параметров
  o.Method(b: "hello", c: true, a: 1);
  // Можно вообще ничего не вызывать
  // (установлены значения по умолчанию у всех параметров)
  o.Method();
  // Можно определить только необходимые параметры
  o.Method(1, "Hello");
  // И не обязательно по порядку
  o.Method(c: false);
}
Теперь из- за переименование параметра метода, код может и не скомпилироваться, если кто-то использовал установку значения по имени, так что нужно быть аккуратнее. Я рад дефолтным значениям, и постараюсь не использовать функциональность именованных параметров.
В дополнение хочу сказать, что если все таки будет у класса Test1 метод void Method(int a), тогда при вызове o.Method(1)вызовится именно он, а не метод из примера с дефолтными значениями.

3. Возможности для COM Interop

DLR так же дал новые возможности для COM Interop, теперь  можно COM объекты определять как динамические (точнее они уже являются в большинстве своем динамического типа) и не приводить постоянно получаемые объекты к определенным типам для вызова методов или свойств.
excel.Cells[1, 1].Value = "Hello";
// вместо 
((Excel.Range)excel.Cells[1, 1]).Value2 = "Hello";
Данный пример взят из документа New Futures in C# 4.0 С одной стороны приятно, что теперь не нужно мучаться и находить к какому же типу нужно привести объект, чтобы вызвать его свойство или метод, но с другой стороны теряется IntelliSense.

4. Новое в generic

Теперь обогатился и generic новой функциональностью. Можно теперь у интерфейсов и у делегатов перед определением generic типов писать out и in, зачем это чуть дальше, а сначала рассмотрим пример.
При работе с generic часто хочется сделать что то типа такого:
IList<string> strings = new List<string>();
IList<object> objects = strings;
Но нельзя. Потому, что следом можно написать:
objects[0] = 5;
string s = strings[0];
То есть, изначально у нас был список строк, потом обозначили его как список объектов, и хотим уже работать с ним, как с объектами, устанавливая любой другой объект в него, хотя список до сих пор является списком строк.
Но, если вдуматься, то можно представить, что если бы список был только для чтения, то мы бы уже не смогли ничего нарушить, и там бы логика была ясна, потому следующий код на C# 4.0 будет работать:
IEnumerable<object> objects = strings;
Огромную полезность данная функциональность принесет в работе с linq, там часто возникают проблемы, что возвращаем объекты одного типа, а нужно получить список другого типа (базового).
Итак, как же такое стало возможным. Сначала рассмотрим слово out. Теперь интерфейс IEnumerable объявлен какIEnumerable, где out обозначает, что тип может быть использован только для возвращения значений, в другом случае компилятор будет ругаться, ну и более того это дает нам, что интерфейс IEnumerable так же есть и IEnumerable, если у есть возможность приведения типа к B, если на простом примере, то IEnumerable, есть теперь и IEnumerable. Вот пример:
public interface IEnumerable<out T> : IEnumerable
{
  IEnumerator GetEnumerator();
}
public interface IEnumerator<out T> : IEnumerator
{
  bool MoveNext();
  T Current { get; }
}
Есть еще слово in. Его так же можно использовать в описании generic делегатов и интерфейсов. Несет оно такую же смысл как и слово out, только в данному случае описанный тип можно использовать только в передаче параметров, вот пример:
public interface IComparer<in T>
{
  public int Compare(T left, T right);
}
То есть в данном случае, если IComparer может считаться и IComparer, потому как если уж он может сравнивать объекты типа object, то и string тоже может.
Так же, как я уже сказал, слова out и in можно применять и к интерфейсам, так, например:
public delegate TResult Func<in TArg, out TResult>(TArg arg);

Заключение

Так же в .NET 4.0 появилось много новвовведений, таких как  Lazy Initialiation - память под объект выделяется тогда, когда это действительно становится нужно. Появились новые типы, как например, BigInteger - теперь не нужно для лабораторных работ студентам писать свои классы для работы с большими числами ;), SortedSet - класс представляет собой самостоятельное балансированное дерево, которое сохраняет данные в отсортированном порядке после вставки, удаления и поиска. В общем, есть еще что изучать.

понедельник, июля 12, 2010

Запуск newresults.ru

Сегодня состоялся запуск портала http://newresults.ru/.

Информационная интернет-площадка для специалистов в области промышленной
переработки молока и сыроделия.
Представляет материалы по технологиям зарубежных сыров (для адаптации
и использования на российских предприятиях), организует обучение новым
технологиям или консультации по улучшению существующих, предлагает индивидуальные решения по подбору сыродельного оборудования.


Если вы не можете найти нужную вам информацию на сайте - пишите администрации : они вам подберут необходимую информацию.  Портал пока находится в режиме наполнения информацией.

Новая карьера : возможности и цели

Пришло приглашение об устройстве на работу в Таском
Буду устраиваться. Должность там интересная. Компания вроде долго уже на рынке ИТ. Как мне видится - есть возможность для карьерного роста. Именно это и ставлю своей целью. О прогрессе по цели буду писать тут

воскресенье, июля 11, 2010

Оплати себе связь и не только

С тех пор как я ушел с работы работаю на фрилансе. И теперь для меня всегда стоит актуальный вопрос быть всегда на связи. Немного поразмыслив я решил что раз-уж я и так вынужден вести сетевую активность то почему-бы не начать иметь  этого бонусы, так сказать.
Рассмотрев несколько вариантов с биржами статей я понял что в это уже становится не актуально - высокая конкуренция среди авторов. И тут я вспомнил что сам с пол-года назад пользовался сервисами blogun.ru . Решил попробовать и вот пришел к выводу что даже при минимальных затратах времени я смогу оплачивать себе и сотовую связь (около 100$/мес) и интернет.
Теперь я считаю что если вы умеете считать деньги - просто не имеете права пропускать такую возможность.

суббота, июля 10, 2010

Создание сайтов


Предлагаю услуги по созданию  сайтов любой сложности (Php или asp.net) а так-же по созданию приложений (полный цикл от выявления требований и выработки ТЗ до ввода в эксплуатацию).
Для уточнения деталей пишите на tvoyfrut (a) g m a i l .com
с пометкой "работа"
Цены на создание сайтов и программ высылаю в ответ на письмо.

четверг, июля 08, 2010

Заработал снова.


Мой блог заработал снова. Теперь тут будет появлятся полезная информация о C# , PHP  и PERL и не только.

пятница, июня 11, 2010

Трансхим


Пластмассы и пластики давно уже стали обычными и привычными материалами. Особенно когда дело касается высокотехнологичных устройств. Практически ни одни гаджет не обходится без применения полимеров как внутри как и снаружи. Мировой производитель полимеров "Трансхим" предлагает широчайший выбор высококачественных материалов : полипропилен, полиэтилен, поликарбонат, поливинилхлорид.

[**На правах рекламы**]