Имитация левитации — 2 / Geektimes

Продолжаю тему про имитацию левитации.

Для тех кто не читал первую публикацию, могут пройти по ссылке

В отличии от первой публикации, в этой статье я продемонстрирую псевдолевитацию воздушных пузырьков в воде.

В начале видео ролика демонстрируется все протестированные мной варианты псевдолевитации, а потом с 3:17 минуты начинаются краткие пояснения. Тем кому надоест смотреть демонстрацию, могут сразу перейти к пояснительной части.


В этой демонстрации используется тот же самый стробоскоп, но немного упрощенный, так как он без электромагнита. Вместо электромагнита в этот раз я использую импульсный, аквариумный насос. Который качает воздух. Работает насос от сети 220В на частоте 25Гц, то есть на половине от частоты сети(50Гц). Почему 25Гц? Потому что насос подключен через один выпрямительный диод. Таким образом диод пропускает только положительные полупериоды.

Что бы синхронизировать пузырьки со вспышками света, стробоскоп нужно настроить на любую кратную частоту 12,5-25-50-75-100 Гц. Соответственно при увеличении частоты стробоскопа в два или и более раз, расстояние между пузырьками будет так же кратно уменьшаться. В видеоролике Вы можете посмотреть фрагмент на
57 секунде, в котором частота увеличена по отношению к 25Гц и пузырьки держатся на очень коротком расстоянии друг от друга.

Схема стробоскопа

Я использую схему на ардуино из прошлого проекта потому, что мне так проще и быстрей. А тем кто хочет повторить проект без ардуино, то могут обойтись обычным таймером на микросхеме NE555.

Используемые в схеме компоненты:

Arduino nano — 1 шт.
Энкодер — 1 шт.
Макетная плата — 1 шт.
Старая LED лампа — 1 шт.
Транзистор КТ972 — 1 шт.
Насос аквариумный — 1шт.
Резистор 120 Ом — 1шт.

Пояснения по схеме:

Светодиодный элемент как я уже говорил, использовал из старой неисправной светодиодной лампы. В которой не работал драйвер.
По напряжению падения на LED элементе выяснил, что его рабочее напряжение 48В.
Что бы уменьшить напряжение питания элемента до 24 В, я поделил элемент на две части, разрезав одну дорожку и запараллелил эти два массива светодиодов.
Так как питание светодиодного элемента осуществляется короткими импульсами, а напряжение питания равно напряжению падения на светодиодах, то ограничивать ток я не стал. Потому как LED элемент все равно работает в ненасыщенном режиме.
Светодиодный элемент коммутируется ключом на транзисторе КТ972. Это составной транзистор или как его еще называют транзистор Дарлингтона, пара Дарлингтона. Можно было применить и MOSFET, но для такого маленького тока и КТ972 слишком много.
Резистор в базе транзистора ограничивает выходной ток контроллера, для того, что бы выход контроллера не вышел из строя. По Datasheet этот ток не должен превышать 40мА. Грубый подсчет, без учета падения напряжения на переходе транзистора будет таким: 5В/0,04А=125 Ом. Так как в линейке сопротивлений такого номинала не бывает, то ставим 120 Ом. Если учесть падение напряжения на переходе транзистора, то ток все равно не превысит 40мА.
Энкодер работает используя всего одно прерывание контроллера INT1
При этом нет надобности бороться аппаратно с дребезгом контактов, так как код с этим справляется, без лишних задержек.
При вращении энкодера без нажатия, изменяется частота. По умолчанию частота в коде 25Гц.
При вращении энкодера с нажатием, изменяется длительность вспышки стробоскопа.
Насос как я писал выше, работает от переменного напряжения 220в на частоте 25 Гц.

Программная часть стробоскопа

Код от прошлого проекта я не стал править, оставил все как есть

Код для ардуино

// Выводы ЭНКОДЕРА
#define CLK 3  // Clock Подключаем к INT1, нельзя переназначать
#define DT 4  // второй вывод энкодера
#define SW 5  // switch кнопка энкодера

#define Min 1 // минимальное значение 
#define Max 20000 //максимальное значение
#define led_pin 12        // подключен светодиод
#define coil_pin A0   

#define step_freq 1       // шаг изменения частоты плавно 0,1гц
#define step_timelght 100 // шаг приращивания в мкс
volatile int freq = 250; // частота в Гц умноженная на 10, для более плавной настройки
volatile uint32_t paus, time_light=2000; // время свечения светодиода в мкс
uint32_t oldcount;
boolean DT_last; // последнее состояние энкодера

void setup()  
{
  pinMode(CLK,INPUT_PULLUP); // Clock Подключаем к INT1, нельзя переназначать
  pinMode(DT, INPUT_PULLUP); // второй вывод энкодера
  pinMode(SW, INPUT_PULLUP); // кнопка энкодера
  pinMode(led_pin, OUTPUT);    // управление симистором
  pinMode(coil_pin, OUTPUT);

  attachInterrupt(1, encoderTick, CHANGE); // прерывания от Энкодера
  
  DT_last = digitalRead(CLK);         // считываем положение CLK
}

void loop()
{
    paus=5000000/freq;
    digitalWrite(coil_pin, 1);
    digitalWrite(led_pin, 1);
    
    oldcount = micros();
    while( (micros() - oldcount) < time_light){}   // длительность импульса выдержки          
    digitalWrite(led_pin, 0);
    while( (micros() - oldcount) < paus){}  // положительный полупериод
    digitalWrite(coil_pin, 0);
    
    oldcount = micros();
    while( (micros() - oldcount) < paus){} //отрицательный полупериод
}

//обработчики прерываний Энкодера
void encoderTick()     // Обработка прерываний от Энкодера
{
  uint8_t DT_now = digitalRead(CLK);       // считываем текущее положение CLK
  
  if (DT_now != DT_last && digitalRead(SW))   // если предыдущее и текущее положение не равны, значит был поворот 
  {                     
    if (digitalRead(DT) != DT_now)    // если DT не равен CLK, значит вращение по часовой стрелке
    {                             
      if( freq < Max ) freq += step_freq;    // прибавить 
    } else {                                   // если DT равен CLK, значит вращение против часовой
             if( freq > Min ) freq -= step_freq;  // убавить            
            }
  } else 
          if (DT_now != DT_last && !digitalRead(SW)) //если нажата кнопка и было вращение
          {
           if (digitalRead(DT) != DT_now)         // если DT не равен CLK, значит вращение по часовой стрелке
            {                             
              if( time_light < paus ) { time_light += step_timelght; } // убавить длительность           
            } else  if( time_light > 0 ) time_light -= step_timelght;    // прибавить длительность импульса выдержки/
          }
          
  DT_last = DT_now;                   // сохранить положение CLK для следующей проверки
}  

Объясню как это работает

Насос с частотой 25 Гц создает давление в трубке, выпуская в импульсе порцию воздуха.
Дозированный воздух в виде пузырьков, выходит из трубки с той же частотой 25Гц и поднимается вверх.
Подстроив стробоскоп на кратную частоту, частоте 25Гц, мы увидим висящие в воде пузыри, так как частоты будут засинхронизированными. И пузырьки будут сменять друг друга, в неактивный момент стробоскопа. Наш глаз этого подлога не заметит, так как он фиксирует только освещенную сцену. В силу физических причин, глаз может видеть только отраженный свет, а то что что происходит в темноте он не видит.

Заключение

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

Если у Вас остались вопросы, задавайте, я на них с удовольствием отвечу.

P.S.

Еще одно видео которое не войдет в серию моих публикаций, но все так же основано на эффекте стробоскопа.

Источник